Mine sisu juurde

Mikrokood

Allikas: Vikipeedia

Protsessori disainis toimib mikrokood vahekihina, mis asub keskseadme (CPU) riistvara ja arvuti programmeerijale nähtava käsustiku, mida tuntakse ka masinkoodina, vahel.[1][lisa lehekülg] See koosneb riistvarataseme käskude komplektist, mis rakendavad kõrgema taseme masinkoodi käske või juhivad sisemise lõpliku olekumasina järjestamist paljudes digitaalsetes töötluskomponentides . Mikrokoodi kasutatakse tänapäevastes laua- ja sülearvutite Inteli ja AMD üldotstarbelistes protsessorites, kuid see toimib vaid varuvariandina olukordades, kus kiirem riistvaraline juhtseade hakkama ei saa. [2]

Mikrokood, mis on paigutatud spetsiaalsesse kiirmälusse, tõlgib masina juhised, olekumasinate andmed või muud sisendandmed üksikasjalikeks ahelatasemel toimingute jadadeks. See eraldab masina juhised aluseks olevast elektroonikast, võimaldades seeläbi suuremat paindlikkust juhiste kavandamisel ja muutmisel. Lisaks sellele hõlbustab see keeruliste mitmeastmeliste juhiste koostamist, vähendades samal ajal arvutilülituste keerukust. Mikrokoodi kirjutamist nimetatakse sageli mikroprogrammeerimiseks ja mikrokoodi konkreetses protsessori rakenduses nimetatakse mõnikord mikroprogrammiks.

Ulatusliku mikroprogrammeerimise abil saavad väiksema ulatuse ja lihtsamad mikroarhitektuurid emuleerida robustsemaid arhitektuure laiema sõnapikkuse, täiendavate täitmisüksuste jne abil. See lähenemisviis pakub suhteliselt lihtsat meetodit, et tagada tarkvara ühilduvus erinevate toodete vahel ühe protsessoriperekonna piires.

Mõned riistvaratootjad, eelkõige IBM ja Lenovo, kasutavad terminit "mikrokood" vaheldumisi "püsivaraga". Selles kontekstis nimetatakse mikrokoodiks kogu seadmes olevat koodi, olenemata sellest, kas tegemist on mikrokoodi või masinkoodiga. Näiteks kõvaketta mikrokoodi uuendused hõlmavad sageli nii mikrokoodi kui ka püsivara värskendusi. [3]

Käsustikudud

[muuda | muuda lähteteksti]

Riistvaralisel tasandil sisaldavad protsessorid mitut eraldiseisvat vooluahela ala ehk „üksust“, mis täidavad erinevaid ülesandeid. Tavaliselt leidub selliseid üksusi nagu aritmeetika-loogikaüksus (ALU), mis täidab selliseid käske nagu liitmine või kahe arvu võrdlemine, ahelad andmete lugemiseks ja kirjutamiseks välismällu ning väikesed pardamälu alad, mis salvestavad neid väärtusi töötlemise ajal. Enamikus konstruktsioonides kasutatakse täiendavat suure jõudlusega mälu, registrifaili, ajutiste väärtuste, mitte ainult jooksva käsu jaoks vajalike väärtuste salvestamiseks. [4]

Käskude nõuetekohaseks täitmiseks peavad erinevad ahelad olema aktiveeritud järjestikku. Näiteks ei ole võimalik liita kahte arvu, kui need ei ole veel mälust laetud. RISC disainides sõltub nende käskude õige järjestus suuresti programmeerijast või vähemalt selle programmeerimiskeele kompilaatorist, mida ta kasutab . Näiteks kahe arvu liitmiseks võib kompilaator anda välja juhised, et laadida üks väärtustest ühte registrisse, teine teise registrisse, kutsuda ALU-s liitmisfunktsiooni ja seejärel kirjutada tulemus tagasi mällu. [4]

Kuna selle kõrgema taseme kontseptsiooni „liida need kaks arvu mälus“ täitmiseks vajalike käskude jada võib nõuda mitut käsku, võib see kujutada endast jõudluse kitsaskohta, kui need käsud on salvestatud põhimällu . Nende juhiste ükshaaval lugemine võtab aega, mida võiks kasutada tegelike andmete lugemiseks ja kirjutamiseks. Sel põhjusel on mitte-RISCi disainilahendustes tavaline, et neil on palju erinevaid juhiseid, mis erinevad suuresti selle poolest, kus nad andmeid salvestavad. Näiteks MOS 6502-l on kaheksa varianti liitmiskäsust ADC, mis erinevad ainult selle poolest, kust nad otsivad kahte operandi. [5]

Kasutades käsu varianti ehk "opkoodi", mis vastab kõige paremini lõplikule operatsioonile, saab käskude arvu vähendada ühele, säästes programmi koodis kasutatavat mälu ja parandades jõudlust, jättes andmesiini teistele operatsioonidele avatuks. Sisemiselt ei ole need juhised siiski eraldi operatsioonid, vaid üksuste poolt tegelikult sooritatavate operatsioonide jadad. Üksiku mälust loetud käsu teisendamine sisemiste toimingute jadaks on protsessori teise üksuse, juhtseadme, ülesanne. [6]

Mikrokoodi põhiidee on asendada käskude järjestamist rakendav kohandatud riistvaraloogika protsessori „mikrokoodimootoris“ käivitatud lihtsate käskude rea abil. Kui kohandatud loogikasüsteemis võib olla rida dioodi ja väravaid, mis väljastavad mitmesugustel juhtliinidel pingeid, siis mikrokoodimootor on ühendatud nende liinidega ning need lülitatakse sisse ja välja, kui mootor loeb järjestikku mikrokoodi juhiseid. Mikrokoodi juhised on sageli nendele liinidele bittkodeeritud, näiteks kui bitt 8 on tõene, võib see tähendada, et ALU peaks andmete ootamiseks pausi tegema. Selles suhtes on mikrokood mõnevõrra sarnane mängijaklaveri paberirullidega, kus augud tähistavad, millist klahvi tuleks vajutada.

Erinevus kohandatud loogika ja mikrokoodi vahel võib tunduda väike, üks kasutab dioodide ja väravate mustrit, et dekodeerida käsk ja toota signaalide jada, samas kui teine kodeerib signaalid mikrokäsudena, mida loetakse järjestikku, et saada sama tulemus. Kriitiline erinevus seisneb selles, et kohandatud loogika disainis nõuavad üksikute sammude muudatused riistvara ümberprojekteerimist. Mikrokoodi kasutamisel muutub ainult mikrokoodi sisaldavasse mällu salvestatud kood. See muudab probleemide parandamise mikrokoodiga süsteemis palju lihtsamaks. See tähendab ka seda, et käskude keerukusele ei ole tegelikku piirangut, seda piirab ainult mälu hulk, mida ollakse valmis kasutama..

Kõige madalam kiht arvuti tarkvaraplaanis on traditsiooniliselt protsessori masinkoodi käsud. Mikrokoodiga protsessorites võib nende käskude kättesaamine ja dekodeerimine ning nende täitmine toimuda mikrokoodi abil. Segaduse vältimiseks eristatakse iga mikroprogrammiga seotud elementi eesliitega micro: microinstruction, microassembler, microprogrammer jne.[7]

Komplekssed digitaalprotsessorid võivad kasutada ka rohkem kui ühte (võimalik, et mikrokoodipõhist) juhtseadet, et delegeerida alamülesandeid, mida tuleb põhimõtteliselt asünkroonselt paralleelselt täita. Näiteks VAX 9000-l on juhtmega ühendatud IBox-üksus käskude toomiseks ja dekodeerimiseks, mis seejärel edastatakse mikrokodeeritud EBox-üksusele täitmiseks [8] ja VAX 8800-l on nii mikrokodeeritud IBox kui ka mikrokodeeritud EBox. [9]

Kõrgetasemeline programmeerija või isegi assemblerkeele programmeerija tavaliselt mikrokoodi ei näe ega muuda. Erinevalt masinkoodist, mis sageli säilitab teatud tagasiühilduvuse ühe protsessoriperekonna erinevate protsessorite vahel, töötab mikrokood ainult täpselt sellel elektroonikalülitusel, mille jaoks see on loodud, kuna see moodustab lahutamatu osa konkreetse protsessori disainist endast.

Tavaliselt kirjutavad insenerid mikrokoodi protsessori disainifaasis, salvestades selle kirjutuskaitstud mällu (ROM) või programmeeritavasse loogikamassiivi (PLA) [10] struktuuri või mõlema kombinatsioonina [11] . Siiski on olemas ka masinaid, mille mikrokood on osaliselt või täielikult salvestatud staatilisse muutmällu (SRAM) või välkmällu . Arvutite kontekstis tähistatakse seda traditsiooniliselt kirjutatava juhtmäluna, mis võib olla kas kirjutuskaitstud või kirjutuskaitstud mälu . Viimasel juhul laadib protsessori initsialiseerimisprotsess mikrokoodi juhtmälusse teiselt salvestuskandjalt, võimalusega muuta mikrokoodi käskude komplekti vigade parandamiseks või uute masinakäskude rakendamiseks.

Mikroprogrammid

[muuda | muuda lähteteksti]

Mikroprogrammid koosnevad mikroinstruktsioonide seeriatest, mis juhivad protsessorit riistvaraahelate väga põhilisel tasemel. Näiteks võib üks tüüpiline horisontaalne mikrokäsk määrata järgmised toimingud:

  • Ühendage register 1 ALU A- poolega
  • Ühendage register 7 ALU B- poolega
  • Seadista ALU kahe täiendi liitmist tegema
  • Seadke ALU kandevõimendi sisend nulliks
  • Salvesta tulemuse väärtus registrisse 8
  • Uuenda ALU olekumärkide seisundikoode ( negatiivne, null, ületäitumine ja ülekanne )
  • Mikrohüpe antud μPC aadressile järgmise mikroinstruktsiooni jaoks

Protsessori kõigi funktsioonide samaaegseks juhtimiseks ühes tsüklis on mikroinstruktsioon sageli laiem kui 50 bitti; nt 128 bitti 360/85-l emulaatorifunktsiooniga. Mikroprogrammid on hoolikalt kavandatud ja optimeeritud võimalikult kiireks täitmiseks, kuna aeglane mikroprogramm tooks kaasa aeglase masinkäsu ja halvenenud jõudluse seotud rakendusprogrammides, mis selliseid käske kasutavad.

Mikrokood töötati algselt välja arvuti juhtimisloogika arendamise lihtsama meetodina. Algselt olid protsessori juhiste komplektid sisseehitatud . Iga masinajuhiste toomiseks, dekodeerimiseks ja täitmiseks vajalikku sammu (sealhulgas operandi aadressi arvutusi, lugemisi ja kirjutamisi) kontrolliti otse kombineeritud loogika ja üsna minimaalse järjestikuse olekumasina vooluringi abil. Kuigi sellised kõvakettaga protsessorid olid väga tõhusad, muutis võimsate, mitmeastmelise adresseerimise ja keerukate toimingutega käskude komplektide vajadus (vt allpool) nende disaini ja silumise keeruliseks; sellele võivad kaasa aidata ka tugevalt kodeeritud ja erineva pikkusega käsud, eriti väga ebaregulaarsete kodeeringute kasutamisel.

Mikrokood lihtsustas tööd, võimaldades suure osa protsessori käitumisest ja programmeerimismudelist defineerida mikroprogrammirutiinide, mitte spetsiaalse vooluringi abil. Isegi disainiprotsessi hilisemas etapis sai mikrokoodi hõlpsasti muuta, samas kui juhtmega protsessori disainide muutmine oli väga tülikas. Seega hõlbustas see oluliselt protsessori disai

1940. aastatest kuni 1970. aastate lõpuni tehti suur osa programmeerimisest assemblerkeeles ; kõrgema taseme käsud tähendasid programmeerija suuremat tootlikkust, seega oli mikrokoodi oluline eelis see, et võimsaid masinkäske saab defineerida suhteliselt lihtsalt. Selle lõplik laiendus on "otseselt täidetavad kõrgetasemelised keeled", kus iga kõrgetasemelise keele, näiteks PL/I, lause täidetakse täielikult ja otse mikrokoodi abil ilma kompileerimiseta. Selle näited on IBM Future Systemsi projekt ja Data General Fountainhead Processor. 1970. aastatel kasvasid protsessori kiirused kiiremini kui mälu kiirused ja selle leevendamiseks kasutati arvukalt tehnikaid, nagu mäluplokkide ülekanne, mälu eellaadimine ja mitmetasandiline vahemälu . Mikrokoodi abil võimalikuks tehtud kõrgetasemelised masinjuhised aitasid veelgi kaasa, kuna vähem keerukamaid masinjuhiseid vajab vähem mälu ribalaiust. Näiteks saab märgijadaga tehtava toimingu teha ühe masinkäsuna, vältides seega mitme käsu hankimist.

Komplekssete mikroprogrammide abil rakendatud käskude komplektidega arhitektuuride hulka kuulusid IBM System/360 ja Digital Equipment Corporation VAX . Üha keerukamate mikrokoodiga rakendatud käskude komplektide lähenemisviisi nimetati hiljem keerukate käskude komplektidega arvutiks (CISC). Alternatiivne lähenemisviis, mida kasutatakse paljudes mikroprotsessorites, on kasutada käskude dekodeerimiseks ühte või mitut programmeeritavat loogikamassiivi (PLA) või kirjutuskaitstud mälu (ROM) (kombinatsiooniloogika asemel) ja lasta lihtsal olekumasinal (ilma suure või olematu mikrokoodita) teha suurem osa sekveneerimisest. MOS Technology 6502 on näide mikroprotsessorist, mis kasutab käskude dekodeerimiseks ja järjestamiseks PLA-d. PLA on nähtav kiibi mikrofotodel [12] ja selle toimimist saab näha transistori tasemel simulatsioonis.

Mikroprogrammeerimist kasutatakse tänapäevastes protsessorite disainides endiselt. Mõnel juhul asendatakse pärast mikrokoodi silumist simulatsioonis juhtmälu loogikafunktsioonidega.[viide?] Loogikafunktsioonid on sageli kiiremad ja odavamad kui samaväärne mikroprogrammimälu.

Protsessori mikroprogrammid töötavad primitiivsemal, täiesti erineval ja palju riistvaralisemal arhitektuuril kui tavalistele programmeerijatele nähtavad assemblerjuhised. Riistvaraga kooskõlas rakendab mikrokood programmeerijale nähtavat arhitektuuri. Aluseks oleval riistvaral ei pea olema nähtava arhitektuuriga fikseeritud suhet. See lihtsustab antud käskude komplekti arhitektuuri rakendamist paljudele alusriistvara mikroarhitektuuridele.

IBM System/360-l on 32-bitine arhitektuur 16 üldotstarbelise registriga, kuid enamik System/360 implementatsioone kasutab riistvara, mis rakendab palju lihtsamat aluseks olevat mikroarhitektuuri; näiteks System/360 mudelil 30 on 8-bitised andmeteed aritmeetilise-loogikaüksusesse (ALU) ja põhimällu ning üldotstarbelised registrid on rakendatud spetsiaalses kiirema põhimälu üksuses, ja System/360 mudelil 40 on 8-bitised andmeteed ALU-sse ja 16-bitised andmeteed põhimällu ning üldotstarbelised registrid on samuti rakendatud spetsiaalses kiirema põhimälu üksuses. Mudelil 50 on täielikud 32-bitised andmeteed ja üldotstarbelised registrid on rakendatud spetsiaalses kiirema põhimälu üksuses. [13] Mudelitel 65 kuni mudelil 195 on pikemad andmesideteed ja üldotstarbelised registrid on rakendatud kiiremates transistoriahelates.[viide?] Sel viisil võimaldas mikroprogrammeerimine IBM-il kujundada palju System/360 mudeleid oluliselt erineva riistvaraga ning laia hinna ja jõudluse vahemikuga, muutes need kõik arhitektuuriliselt ühilduvaks. See vähendab dramaatiliselt iga mudeli jaoks kirjutatavate unikaalsete süsteemitarkvaraprogrammide arvu.

Sarnast lähenemisviisi kasutas Digital Equipment Corporation (DEC) oma VAX arvutiperekonnas. Seetõttu kasutavad erinevad VAX-protsessorid erinevaid mikroarhitektuure, kuid programmeerijale nähtav arhitektuur ei mu

Mikroprogrammeerimine vähendab ka protsessori vigade (vigade) parandamiseks vajalike muudatuste kulusid; vea saab sageli parandada mikroprogrammi osa asendamise, mitte riistvaraloogika ja juhtmestiku muutmise teel.

Varased näited

[muuda | muuda lähteteksti]

1947. aastal tutvustas MIT Whirlwindi disain juhtploki kontseptsiooni, et lihtsustada arvutidisaini ja liikuda kaugemale ad hoc meetoditest. Juhtmälu on dioodmaatriks : kahemõõtmeline võre, kus üks dimensioon võtab vastu protsessori sisemiselt kellalt "juhtimisaja impulsse" ja teine ühendub väravate ja muude vooluringide juhtsignaalidega. "Impulssijaotur" võtab protsessori kella genereeritud impulsid ja jagab need kaheksaks eraldi ajaimpulsiks, millest igaüks aktiveerib võre erineva rea. Kui rida aktiveeritakse, aktiveeritakse sellega ühendatud juhtsignaalid.

1951. aastal täiustas Maurice Wilkes seda kontseptsiooni, lisades tingimusliku täitmise, mis on sarnane arvutitarkvara tingimusliku täitmise kontseptsiooniga. Tema esialgne teostus koosnes kahest maatriksist: esimene genereeris signaale Whirlwindi juhtmälu viisil, teine maatriks aga valis, millist signaalirida (niiöelda mikroprogrammi käsusõna) järgmisel tsüklil kutsuda. Tingimuslaused rakendati nii, et üks rida juhtsalves sai valida teise maatriksi alternatiivide hulgast. See muutis juhtsignaalid sõltuvaks tuvastatud sisemisest signaalist. Wilkes lõi selle funktsiooni kirjeldamiseks ja lihtsast juhtsalvestusest eristamiseks termini mikroprogrammeerimine .

 Pikemalt artiklis System/360

Mikrokood jäi arvutidisainis suhteliselt haruldaseks, kuna koodi salvestamiseks vajaliku ROM-i maksumus ei erinenud oluliselt kohandatud juhtimisloogika maksumusest. See muutus 1960. aastate alguses, kui turule toodi masstootmises olev põhimälu ja põhikaabel, mis oli palju odavam kui dioodimassiividel või sarnastel lahendustel põhinev spetsiaalne loogika. Esimene, kes seda tegelikult ära kasutas, oli IBM oma 1964. aasta System/360 seerias. See võimaldas masinatel omada väga keerukat käskude komplekti, mis sisaldas operatsioone, mis sobisid kõrgetasemeliste keelekonstruktsioonidega, näiteks binaarväärtuste vormindamine kümnendstringideks, kodeerides selle ülesande jaoks vajalikke keerulisi sisemisi samme odavas mälus. [14]

Kuid 360 seeria tegelik väärtus seisnes selles, et sai ehitada rea masinaid, mis olid sisemiselt täiesti erinevad, kuid käitasid sama ISA-d. Madalama klassi masina puhul võidakse kasutada 8-bitist ALU-d, mis nõuab ühe 32-bitise liitmise lõpetamiseks mitut tsüklit, samas kui kõrgema klassi masinal võib olla täielik 32-bitine ALU, mis teeb sama liitmise ühe tsükliga. Neid erinevusi saaks rakendada juhtimisloogikas, kuid iga masina jaoks täiesti erineva dekoodri rakendamine oleks liiga kulukas. Mikrokoodi kasutamine tähendas, et muutus ainult ROM-is olev kood. Näiteks võib üks masin sisaldada ujukomaühikut ja seega võib selle kahe arvu korrutamiseks mõeldud mikrokood olla vaid paar rida pikk, samas kui samal masinal ilma ujukomaüksuseta oleks see programm, mis teeks sama mitme liitmise abil, ja ainus, mis muutuks, oleks ROM. [14]

Selle disaini tulemuseks oli see, et kliendid said oma tarkvara arendamiseks kasutada perekonna odavamat mudelit, teades, et kui kunagi peaks vaja minema suuremat jõudlust, saavad nad minna üle kiiremale versioonile ja miski muu ei muutu. See alandas sisenemisbarjääri ja 360 oli meeletu edu. Kümnendi lõpuks oli mikrokoodi kasutamine suurarvutite tööstuses kohustuslik.

Liikudes reast ülespoole

[muuda | muuda lähteteksti]
Motorola 68000 mikrokood (ja "nanokood") on salvestatud kahes suures ruudukujulises plokis paremas ülanurgas ja seda juhib paremal asuv vooluring. See võtab enda alla märkimisväärse osa kiibi kogupinnast.

Varased miniarvutid olid mikrokoodi vajamiseks liiga lihtsad ning olid oma käskude komplektide ja dekodeerimisviisi poolest sarnasemad varasemate suurarvutitega. Kuid peagi hakkasid nende disainerid kasutama võimsamaid integraallülitusi, mis võimaldasid keerukamaid ISA-sid. 1970. aastate keskpaigaks kasutas enamik uusi mini- ja superminiarvuteid samuti mikrokoodi, näiteks enamik PDP-11 mudeleid ja, mis kõige tähelepanuväärsem, enamik VAX-i mudeleid, mis sisaldasid kõrgetasemelist õpet, mis sarnanes 360-s leiduvatele. [15]

Sama põhiline areng toimus ka mikroprotsessoritega. Varased disainid olid väga lihtsad ja isegi võimsamatel 8-bitistel 1970. aastate keskpaiga disainidel, nagu Zilog Z80, olid juhiste komplektid, mis olid piisavalt lihtsad, et neid saaks spetsiaalses loogikas rakendada. Selleks ajaks sai juhtimisloogika olla mustritud samale kiibile kui protsessor, mistõttu ROM-i ja loogika hinnavahe pole enam nii suur probleem. Siiski ei läinud kaua aega, kui ka need ettevõtted seisid silmitsi probleemiga, kuidas tutvustada suurema jõudlusega disainilahendusi, kuid soovisid siiski pakkuda tagasiühilduvust . Üks mikrokoodi varajastest näidetest mikrosüsteemides oli Intel 8086. [6]

Üks mikroprotsessorites mikrokoodi lõplikke rakendusi on Motorola 68000. See pakkus väga ortogonaalset käskude komplekti laia valiku adresseerimisrežiimidega, mis kõik olid rakendatud mikrokoodis. See ei tulnud ilma kuludeta, varajaste artiklite kohaselt moodustab mikrokoodisüsteem umbes 20% kiibi pindalast (ja seega ka maksumusest) ja [viide?] süsteemidest 68 000 transistori olid osa mikrokoodisüsteemist.

Kuigi ettevõtted jätkasid konkureerimist oma käskude komplektide keerukuse osas ja mikrokoodi kasutamine nende rakendamiseks oli vaieldamatu, tekitas IBM-i siseprojekt 1970. aastate keskel tõsiseid küsimusi kogu kontseptsiooni kohta. Osana projektist, mille eesmärk oli arendada välja suure jõudlusega täisdigitaalne telefonikommutaator, hakkas John Cocke'i juhitud meeskond uurima tohutul hulgal jõudlusandmeid oma klientide 360 (ja System/370 ) programmidest. See pani nad märkama kummalist mustrit: kui ISA esitas käsust mitu versiooni, kasutas kompilaator peaaegu alati kõige lihtsamat, mitte seda, mis koodi kõige otsesemalt esindas. Nad said teada, et see oli nii, kuna need juhised olid alati riistvaras rakendatud ja seega töötasid need kõige kiiremini. Teise käsu kasutamine võis mõne masina puhul pakkuda paremat jõudlust, kuid polnud mingit võimalust teada, millisel masinal need töötavad. See nullis mikrokoodi kasutamise eesmärgi, milleks oli nende erinevuste varjamine. [16]

Selle avastuse tulemuseks oli see, mida tänapäeval tuntakse RISC -kontseptsioonina. Kompleksne mikrokoodimootor ja sellega seotud ROM on vähendatud või täielikult eemaldatud ning need vooluringid on selle asemel pühendatud sellistele asjadele nagu lisaregistrid või laiem ALU, mis suurendab iga programmi jõudlust. Kui on vaja keerulisi käskude jadasid, jäetakse see kompilaatori hooleks, mis ongi kompilaatori kasutamise eesmärk. Põhikontseptsiooni võtsid peagi omaks California ülikooli teadlased, kus simulatsioonid näitasid, et sellised konstruktsioonid edestavad triviaalselt isegi kiireimaid tavapäraseid konstruktsioone. Just üks selline projekt California Ülikoolis Berkeleys tutvustas terminit RISC.

Tööstus reageeris RISC kontseptsioonile nii segaduse kui ka vaenulikkusega, sealhulgas avaldas Digitali VAX-i meeskond kuulsa halvustava artikli. [17] Peamine vaidluspunkt oli see, et käskude rakendamine väljaspool protsessorit tähendas, et protsessor kulutaks nende käskude lugemisele mälust palju rohkem aega, aeglustades seeläbi üldist jõudlust olenemata sellest, kui kiiresti protsessor ise töötas. [17] Pooldajad tõid välja, et simulatsioonid näitasid selgelt, et käskude arv ei olnud palju suurem, eriti kompileeritud koodi puhul. [16]

Arutelu möllas kuni esimeste kommertslike RISC-disainide ilmumiseni 1980. aastate teisel poolel, mis edestasid kergesti teiste ettevõtete kõige keerukamaid disainilahendusi. 1980. aastate lõpuks oli see läbi; isegi DEC loobus oma DEC Alpha disainides mikrokoodist ja CISC protsessorid läksid paljude funktsioonide täitmiseks üle mikrokoodi asemel juhtmega vooluringidele. Näiteks Intel 80486 kasutab käskude toomiseks ja dekodeerimiseks juhtmega vooluringi, täites käske ainult mikrokoodi abil; registritevahelise liikumise ja aritmeetilised käsklused vajasid ainult ühte mikrokäsku, mis võimaldas neid täita ühe taktsükli jooksul. Pentium Pro protsessori toomise ja dekodeerimise riistvara toob käsud ja dekodeerib need mikrooperatsioonide seeriateks, mis edastatakse täitmisüksusele, mis ajastab ja käivitab mikrooperatsioonid, tehes seda võimalik , et vales järjekorras . Keerulisi juhiseid rakendatakse mikrokoodi abil, mis koosneb eelnevalt määratletud mikrooperatsioonide järjestustest. [18]

Mõned protsessori disainid kasutavad spetsiaalses režiimis töötavat masinkoodi, millel on spetsiaalsed juhised, mis on saadaval ainult selles režiimis ja millel on juurdepääs protsessorist sõltuvale riistvarale, et rakendada juhiste komplekti mõningaid madala taseme funktsioone. DEC Alpha, mis on puhas RISC-disain, kasutas PALcode'i selliste funktsioonide rakendamiseks nagu translation lookaside bufferi (TLB) möödalaskmiste ja katkestuste käsitlemine [19], samuti pakkus Alpha-põhistele süsteemidele, mis käitavad OpenVMS-i, juhiseid, mis nõuavad blokeeritud mälule juurdepääsu ja on sarnased VAX- arhitektuuri pakutavate juhistega [19] . CMOS-protsessorid IBM System/390 protsessorid, alates G4 protsessorist, ja z/Architecture protsessorid kasutavad mõnede käskude rakendamiseks millikoodi . [20]

  • Charles Babbage'i ette kujutatud analüütiline mootor kasutab sisemiste protseduuride salvestamiseks pöörlevatesse trumlitesse sisestatud pulki .
  • Väidetavalt kasutab EMIDEC 1100 [21] juhtmega ühendatud juhtmälu, mis koosneb ferriitsüdamikesse ehk "pitsidesse" keeratud juhtmetest.
  • Enamik IBM System/360 seeria mudeleid on mikroprogrammeeritud:
    • Model 25 on System/360 mudelite seas ainulaadne, kuna see kasutab 16 parimat. K baiti põhimälu mikroprogrammi juhtmälu hoidmiseks. 2025 kasutab 16-bitist mikroarhitektuuri seitsme juhtsõnaga (või mikroinstruktsiooniga). Pärast süsteemi hooldust või töörežiimi muutmisel laaditakse mikrokood kaardilugejast, lindilt või muult seadmelt. [22] Selle mudeli IBM 1410 emuleerimine laaditakse sel viisil.
    • Mudel 30 kasutab 8-bitist mikroarhitektuuri, millel on vaid mõned riistvararegistrid; kõike, mida programmeerija nägi, emuleeris mikroprogramm. Selle mudeli mikrokoodi hoitakse ka spetsiaalsetel perfokaartidel, mis salvestatakse masina sees iga kaardi jaoks eraldi lugejas, mida nimetatakse "CROS"-seadmeteks (Capacitor Read-Only Storage). [23] : 2–5 1401/1440/1460 emuleerimisega tellitud masinatele on lisatud veel üks CROS-seade [23] : 4–29 ja masinate puhul, mis on tellitud 1620 emuleerimisega. [23] : 4–75 
    • Mudel 40 kasutab 56-bitiseid juhtsõnu. 2040. aasta karp rakendab nii System/360 põhiprotsessorit kui ka multiplekskanalit (I/O protsessorit). See mudel kasutab CROS- seadmetega sarnaseid spetsiaalseid TROS- lugereid, kuid induktiivse lugemissensoriga (Transformer Read-only Store).
    • Mudelil 50 on kaks sisemist paralleelselt töötavat andmeteed: 32-bitine andmetee, mida kasutatakse aritmeetiliste operatsioonide jaoks, ja 8-bitine andmetee, mida kasutatakse mõnede loogiliste operatsioonide jaoks. Juhtmälu kasutab 90-bitiseid mikroinstruktsioone.
    • Mudelil 85 on eraldi käskude hankimine (I-üksus) ja täitmine (E-üksus), et tagada kõrge jõudlus. I-üksus on riistvaraliselt juhitav. E-üksus on mikroprogrammeeritud; juhtsõnad on tavalisel 360/85-l 108 bitti laiad ja emulaatorifunktsiooni installimisel laiemad.
  • NCR 315 on mikroprogrammeeritud käsitsi juhtmestatud ferriitsüdamikega ( ROM ), mida impulsseerib tingimusliku täitmisega sekventser. Südamike kaudu suunatud juhtmed on lubatud protsessori erinevate andmete ja loogikaelementide jaoks.
  • Digital Equipment Corporationi PDP-9 protsessor, KL10 ja KS10 PDP-10 protsessorid ning PDP-11 protsessorid (välja arvatud PDP-11/20) on mikroprogrammeeritud. [24]
  • Enamik Data General Eclipse'i miniarvuteid on mikroprogrammeeritud. Eclipse MV/8000 mikrokoodi kirjutamise ülesannet on üksikasjalikult kirjeldatud Pulitzeri preemia võitnud raamatus pealkirjaga "Uue masina hing" .
  • Paljud Burroughsi süsteemid on mikroprogrammeeritud:
  • B700 "mikroprotsessor" täidab rakendustaseme koode, kasutades põhimällu salvestatud 16-bitiste mikroinstruktsioonide jadasid; igaüks neist on kas registri laadimise operatsioon või kaardistatud üheks 56-bitiseks "nanokoodi" käsuks, mis on salvestatud kirjutuskaitstud mällu. See võimaldab suhteliselt lihtsal riistvaral toimida kas suurarvuti välisseadme kontrollerina või olla pakendatud eraldiseisva arvutina.
  • B1700 on rakendatud radikaalselt erineva riistvaraga, sealhulgas bitiaadresseeritava põhimäluga, kuid sellel on sarnane mitmekihiline organisatsioon. Operatsioonisüsteem laadib eelnevalt üles tõlgi mis tahes keele jaoks. Need interpretaatorid esitlevad erinevaid virtuaalmasinaid COBOLi, Fortrani jne jaoks.
  • Mikroandmete abil loodi arvuteid, mille mikrokood on kasutajale ligipääsetav; see võimaldab luua kohandatud assembleri tasemel juhiseid. Microdata Reality operatsioonisüsteemi disain kasutab seda võimalust laialdaselt.
  • Xerox Alto tööjaam kasutas mikrokoodiga disaini, kuid erinevalt paljudest arvutitest pole mikrokoodimootor programmeerija eest kihilise disaini tõttu peidetud. Rakendused kasutavad seda ära jõudluse kiirendamiseks.
  • IBM System/38-l on kirjeldatud nii horisontaalne kui ka vertikaalne mikrokood . [25] Praktikas rakendab protsessor horisontaalse mikrokoodi vormingu abil käskude komplekti arhitektuuri nimega Internal Microprogrammed Interface (IMPI). Nn vertikaalne mikrokoodi kiht rakendab System/38 riistvarast sõltumatut masinliidese (MI) käskude komplekti, teisendades MI-koodi IMPI-koodiks ja käivitades seda. Enne IBM RS64 protsessorisarja turuletoomist kasutasid varased IBM AS/400 süsteemid sama arhitektuuri. [26]
  • Nintendo 64 reaalsuskoprotsessor (RCP), mis toimib konsooli graafikaprotsessori ja heliprotsessorina, kasutab mikrokoodi; soovitud väljundi saavutamiseks on võimalik rakendada uusi efekte või protsessorit kohandada. Mõned tähelepanuväärsed näited kohandatud RCP mikrokoodist hõlmavad kõrgresolutsioonilist graafikat, osakestemootoreid ja piiramatuid joonistuskaugusi, mida leidub Factor 5 mängudes "Indiana Jones and the Infernal Machine", "Star Wars: Rogue Squadron" ja "Star Wars: Battle for Naboo" ; [27] [28] ning täisliikumisvideote taasesitust Angel Studiose mängus "Resident Evil 2". [29]
  • Sony PlayStation 2 vektorüksused VU0 ja VU1 on mikroprogrammeeritavad; tegelikult on VU1 SDK esimeste põlvkondade jooksul ligipääsetav ainult mikrokoodi kaudu.
  • MicroCore Labs MCL86 Archived , MCL51 Archived ja MCL65 Archived on näited Intel 8086/8088, 8051 ja MOS 6502 kiipide tugevalt kodeeritud "vertikaalsetest" mikrosekventseri rakendustest.
  • Digital Scientific Corp. Meta 4 Series 16 arvutisüsteem oli kasutaja poolt mikroprogrammeeritav süsteem, mis oli esmakordselt saadaval 1970. aastal. Mikrokoodil oli peamiselt vertikaalne stiil 32-bitiste mikroinstruktsioonidega. [30] Juhised salvestati vahetatavatele programmiplaatidele, millel oli bitipositsioonide ruudustik. Üks (1) bitt oli esindatud väikeste metallruutudega, mida võimendid tuvastasid, null (0) bitti aga ruutude puudumisega. [31] Süsteemi saab konfigureerida kuni 4K 16-bitiste sõnadega mikrosalvestusega. Üks Digital Scientificu toodetest oli IBM 1130 emulaator. [32] [33]
  • MCP-1600 on Western Digitali poolt aastatel 1975 kuni 1980. aastate alguseni toodetud mikroprotsessor . Seda kasutati kolme erineva arvutiarhitektuuri rakendamiseks mikrokoodis: Pascal MicroEngine, WD16 ja DEC LSI-11, mis on soodsam PDP-11. [34]
  • Varasemad x86 protsessorid on täielikult mikrokodeeritud. x86 protsessorid rakendasid paigatavat mikrokoodi (paigaldus BIOS-i või operatsioonisüsteemi poolt) alates Inteli P6 mikroarhitektuurist ja AMD K7 mikroarhitektuurist . Sellised protsessorid rakendasid oma ränil mikrokoodi ROM-i ja mikrokoodi SRAM-i.
  • Paljud videokaardid ja võrguliidese kontrollerid kasutavad paigatavat mikrokoodi (paigaldus operatsioonisüsteemi järgi). Selline mikrokood on paigutatud seadme SRAM-i või DRAM-i, näiteks videokaardi GDDR SDRAM-i külge.

Rakendamine

[muuda | muuda lähteteksti]

Mikroprogrammi iga mikrokäsklus annab bitid, mis kontrollivad funktsionaalseid elemente, mis sisemiselt moodustavad protsessori. Eeliseks kõvakoodiga protsessori ees on see, et protsessori sisemine juhtimine muutub arvutiprogrammi spetsialiseeritud vormiks. Mikrokood muudab seega keerulise elektroonilise disaini ülesande (protsessori juhtimine) vähem keeruliseks programmeerimisülesandeks. Selle eelise ärakasutamiseks on protsessor jagatud mitmeks osaks:

  • I-üksus võib riistvaraliselt käske dekodeerida ja määrata mikrokoodi aadressi käsu töötlemiseks paralleelselt E-üksusega .
  • Mikrosekventser valib juhtmälust järgmise sõna. Sekventser on enamasti loendur, kuid tavaliselt on sellel ka mingi viis hüpata juhtmälu teise ossa, olenevalt mingitest andmetest, tavaliselt käskude registri andmetest ja alati juhtmälu mingist osast. Lihtsaim sekventser on lihtsalt register, mis laaditakse juhtmälu mõnest bitist.
  • Registrikomplekt on kiire mälu, mis sisaldab keskseadme andmeid. See võib sisaldada rakendusprogrammidele nähtavaid registreid, näiteks üldotstarbelisi registreid ja programmiloendurit, ning võib sisaldada ka muid registreid, millele rakendusprogrammeerijal pole hõlpsasti juurdepääsu. Tihti on registrikomplekt kolmekordselt portitud registrifail ; see tähendab, et kahte registrit saab lugeda ja kolmandasse saab samaaegselt kirjutada.
  • Aritmeetika-loogikaplokk teostab arvutusi, tavaliselt liitmist, loogilist eitust, paremale nihutamist ja loogilist JA-tehteid. Sageli täidab see ka muid funktsioone.

Samuti võib olla mälu aadressiregister ja mälu andmeregister, mida kasutatakse arvuti põhimälule juurdepääsuks. Koos moodustavad need elemendid " täitmisüksuse ". Enamikul tänapäevastel protsessoritel on mitu täitmisüksust. Isegi lihtsatel arvutitel on tavaliselt üks seade mälu lugemiseks ja kirjutamiseks ning teine kasutajakoodi käivitamiseks. Neid elemente saab sageli ühendada üheks tervikuks. See kiip on fikseeritud laiusega, mis moodustaks teostusüksusest "viilu". Neid tuntakse " bitiviilude " kiipidena. AMD Am2900 perekond on üks tuntumaid bitiviiluelementide näiteid. [35] Täitmisüksuste osad ja terviküksused on omavahel ühendatud juhtmete kimbuga, mida nimetatakse siiniks .

Programmeerijad arendavad mikroprogramme, kasutades põhilisi tarkvaratööriistu. Mikroassembler võimaldab programmeerijal bittide tabelit sümboolselt defineerida. Tänu oma tihedale seosele alusarhitektuuriga on "mikrokoodil mitu omadust, mis raskendavad selle genereerimist kompilaatori abil." [1] Simulaatorprogramm on mõeldud bittide täitmiseks samamoodi nagu elektroonika ning see annab mikroprogrammi silumiseks palju suurema vabaduse. Pärast mikroprogrammi valmimist ja põhjalikku testimist kasutatakse seda mõnikord sisendina arvutiprogrammile, mis loob loogika samade andmete genereerimiseks.[viide?] See programm sarnaneb programmeeritava loogikamassiivi optimeerimiseks kasutatavatele programmidele. Isegi ilma täielikult optimaalse loogikata võib heuristiliselt optimeeritud loogika transistoride arvu oluliselt vähendada kirjutuskaitstud mälu (ROM) juhtsalvestuse jaoks vajalikust arvust. See vähendab protsessori tootmiskulusid ja selle poolt tarbitavat elektrit.

Mikrokoodi saab iseloomustada horisontaalse või vertikaalsena, viidates peamiselt sellele, kas iga mikroinstruktsioon juhib protsessori elemente vähese või ilma dekodeerimiseta (horisontaalne mikrokood) [a] või nõuab enne seda ulatuslikku dekodeerimist kombinatoorse loogika abil (vertikaalne mikrokood). Järelikult on iga horisontaalne mikroinstruktsioon laiem (sisaldab rohkem bitte) ja võtab rohkem salvestusruumi kui vertikaalne mikroinstruktsioon.

Horisontaalne mikrokood

[muuda | muuda lähteteksti]

„Horisontaalses mikrokoodis on mitu eraldiseisvat mikrooperatsiooni, mis on kombineeritud üheks mikrokäsuks, et töötada samaaegselt.“[1] Horisontaalne mikrokood sisaldub tavaliselt üsna laias juhtimismälus; ei ole haruldane, et iga sõna on 108 bitti või rohkem. Iga järjestikuse taktimuutuse ajal loetakse mikrokoodi sõna, dekodeeritakse ja kasutatakse protsessori funktsionaalsete elementide juhtimiseks.

Tüüpilises rakenduses koosneb horisontaalne mikroprogrammi sõna üsna täpselt määratletud bitide rühmadest. Näiteks võib üks lihtne paigutus olla järgmine:

Registriallikas A Registriallikas B Siht register Aritmeetilise-loogikaplokki opereerimine Hüppe tüüp Hüppe aadress

Sellise mikrokoodi puhul võib mikrokood nõuda kahe taktimuutust, et rakendada JUMP-käsklust, mille aadress järgneb opkoodile. Seda projekteeriv insener kirjutaks mikroassembleri lähtekoodi, mis näeb välja umbes nii:

   # Iga rida, mis algab numbrimärgiga, on kommentaar.
   # See on lihtsalt silt, tavaline viis, kuidas assemblerid sümboolselt esitavad
   # mälu aadressi.
 InstructionJUMP:
       # Järgmise käsu ettevalmistamiseks on käsu dekodeerimise mikrokood juba
       # liigutanud programmi loenduri mälu aadressiregistrisse. See käsk hangib
       # hüppekäsu sihtaadressi mälusõnast, mis järgneb mälusõnale
       # hüppe opkoodi, kopeerides mälu andmeregistrist mälu aadressiregistrisse.
       # See annab mälusüsteemile kaks taktimõõtu järgmise taktimõõtu noppimiseks
       # käsk mäluandmete registrisse, et seda saaks kasutada käsu dekodeerimiseks.
       # Järjekorra käsk „next“ tähendab lihtsalt 1 lisamist juhtimissõna aadressile.
    MDR, NONE, MAR, COPY, NEXT, NONE
       # See paigutab järgmise käsu aadressi PC-sse.
       # See annab mälusüsteemile tiksu, et lõpetada otsing, mida alustati
       # eelmise mikrokäsuga.
       # Järjekorra käsk on hüpata käsu dekodeerimise algusesse.
    MAR, 1, PC, ADD, JMP, InstructionDecode
       # Käskude dekodeerimine ei ole näidatud, sest see on tavaliselt segadus, väga konkreetne
       # täpselt emuleeritavale protsessorile. Isegi see näide on lihtsustatud.
       # Paljudel protsessoritel on mitmeid viise aadressi arvutamiseks, mitte ainult väljavõtete tegemiseks.
       # seda op-koodile järgnevast sõnast. Seega, selle asemel, et ainult üks
       # hüppekäsu asemel on neil protsessoritel perekond seotud hüppekäske.

Iga takti puhul on tavaline, et kasutatakse ainult osa protsessorist, ülejäänud mikrokäskude bittide rühmad on no-ops. Hoolika riistvara- ja mikrokoodidisaini korral saab seda omadust ära kasutada, et sooritada paralleelseid operatsioone, kasutades protsessori eri piirkondi; näiteks ülaltoodud juhul ei ole ALU-d esimese taktimuutuse ajal vaja, seega võib seda potentsiaalselt kasutada varasema aritmeetilise käsu täitmiseks.

Vertikaalne mikrokood

[muuda | muuda lähteteksti]

Vertikaalses mikrokoodis on iga mikrokäsklus oluliselt kodeeritud, st bittiväljad läbivad üldiselt vahepealset kombineerimisloogikat, mis omakorda genereerib protsessori sisemiste elementide (ALU, registrid jne) juhtimis- ja järjestussignaalid. See on vastupidine horisontaalsele mikrokoodile, kus bittiväljad kas toodavad otse juhtimis- ja järjestussignaalid või on ainult minimaalselt kodeeritud. Sellest tulenevalt nõuab vertikaalne mikrokood väiksemat käsu pikkust ja vähem salvestusruumi, kuid selle dekodeerimiseks kulub rohkem aega, mille tulemuseks on aeglasem protsessoritakt. [36]

Mõni vertikaalne mikrokood on lihtsalt lihtsa tavalise arvuti assemblerkeel, mis emuleerib keerukamat arvutit. Mõned protsessorid, näiteks DEC Alpha protsessorid ja hilisemate IBM-i suurarvutite System/390 ja z/Architecture CMOS-mikroprotsessorid, kasutavad masinkoodi, mis töötab spetsiaalses režiimis, mis annab sellele juurdepääsu spetsiaalsetele käskudele, registritele ja muudele riistvararessurssidele, mis tavalisele masinkoodile kättesaamatud pole, et rakendada mõningaid käske ja muid funktsioone [37] [38] näiteks leheküljetabelite vahel käimisi Alpha protsessorites. [39] Alpha protsessoritel nimetatakse seda PALcode'iks ja IBM-i suurarvuti protsessoritel millicode'iks .

Välja valimine Välja väärtus

Väljaga select valitakse, millist protsessori osa see juhtimissalvestuse sõna kontrollib. Välja väärtus kontrollib seda osa protsessorist. Seda tüüpi mikrokoodi puhul otsustab projekteerija selgesõnaliselt teha aeglasema protsessori, et säästa raha, vähendades kasutamata bitide arvu juhtimissalves; vähendatud keerukus võib aga suurendada protsessori taktsagedust, mis vähendab suurenenud tsüklite arvu mõju ühe käsu kohta.

Kuna transistorid muutusid odavamaks, hakkas mikrokoodi kasutavate protsessorite projekteerimisel domineerima horisontaalne mikrokood ja vertikaalset mikrokoodi kasutati harvemini.

Kui kasutatakse nii vertikaalset kui ka horisontaalset mikrokoodi, võib horisontaalset mikrokoodi nimetada nanokoodiks või pikokoodiks. [40]

Kirjutatav juhtmälu

[muuda | muuda lähteteksti]
 Pikemalt artiklis Kirjutatav juhtmälu

Mõned arvutid ehitati kirjutatavat mikrokoodi kasutades. Selle konstruktsiooni puhul salvestatakse mikrokood ROMi või kõvakoodiga ühendatud loogika asemel mikrokood RAM-i, mida nimetatakse kirjutatavaks kontrollsalveks (WCS). Sellist arvutit nimetatakse mõnikord kirjutatavaks käsurea arvutiks (WISC). [41]

Paljud eksperimentaalsed prototüüparvutid kasutavad kirjutatavaid juhtmäluseadmeid ; on ka kommertsmasinaid, mis kasutavad kirjutatavat mikrokoodi, näiteks Burroughs Small Systems, varased Xeroxi tööjaamad, DEC VAX 8800 ( Nautilus ) perekond, Symbolics L- ja G-masinad, mitmed IBM System/360 ja System/370 rakendused, mõned DEC PDP-10 masinad ja Data General Eclipse MV/8000 . [42]

IBM System/370 sisaldab funktsiooni Initial-Microprogram Load ( IML või IMPL ) [43], mida saab käivitada konsoolist, sisselülituslähtestuse ( POR ) osana või mõnelt teiselt protsessorilt tihedalt seotud mitmeprotsessorilises kompleksis.

Mõnedel kommertsmasinatel, näiteks IBM 360/85- [44] [45] on mikrokoodi jaoks nii kirjutuskaitstud kui ka kirjutatav juhtmälu.

WCS pakub mitmeid eeliseid, sealhulgas mikroprogrammi paikamise lihtsust ja teatud riistvarapõlvkondade puhul kiiremat juurdepääsu kui ROM-id suudavad pakkuda. Kasutaja programmeeritav WCS võimaldab kasutajal masinat konkreetseteks eesmärkideks optimeerida.

Alates Pentium Pro-st 1995. aastal on mitmel x86 protsessoril kirjutatav Inteli mikrokood . [46] See on näiteks võimaldanud parandada Intel Core 2 ja Intel Xeoni mikrokoodide vigu nende mikroprogrammide lappimise teel, selle asemel et nõuda tervete kiipide väljavahetamist. Teine silmapaistev näide on mikrokoodiparanduste komplekt, mida Intel pakkus mõnele oma kuni 10 aasta vanusele protsessoriarhitektuurile, et võidelda 2018. aasta alguses avalikuks tulnud disainilahendustes – Spectre ja Meltdown – avastatud turvanõrkustega [47] Mikrokoodi värskenduse saab installida Linuxi, [48] FreeBSD, [49] Microsoft Windowsi [50] või emaplaadi BIOS-i [51] kaudu.

Mõned masinad pakuvad lisavarustusena kasutaja programmeeritavaid kirjutatavaid juhtmäluseadmeid, sealhulgas HP 2100, DEC PDP-11/60, TI-990 /12 [52] [53] ja Varian Data Machines V-70 seeria miniarvutid .

Võrdlus VLIW ja RISC-ga

[muuda | muuda lähteteksti]

Tugevalt mikrokodeeritud ja keerukate käskudega protsessorite väljatöötamise suundumus algas 1960ndate alguses ja jätkus umbes 1980ndate keskpaigani. Sel ajal hakkas RISC-kujundusfilosoofia üha enam esile kerkima.

Mikrokoodi kasutaval protsessoril kulub ühe käsu täitmiseks tavaliselt mitu taktsüklit, üks taktsükkel iga sammu kohta selle käsu mikroprogrammis. Mõned CISC-protsessorid sisaldavad juhiseid, mille täitmine võib võtta väga kaua aega. Sellised variatsioonid häirivad nii katkestuste latentsust kui ka, mis on kaasaegsetes süsteemides palju olulisem, pipelinegi .

Uue protsessori projekteerimisel on juhtmega juhtimisega RISC-l mikrokodeeritud CISC-i ees järgmised eelised:

  • Programmeerimine on suures osas assemblertasemelt eemaldunud, seega pole tootlikkuse huvides enam keerukate juhiste andmine mõttekas.
  • Lihtsamad käskude komplektid võimaldavad riistvaralist otsest täitmist, vältides mikrokoodiga täitmisega kaasnevat jõudluse langust.
  • Analüüs näitab, et keerulisi juhiseid kasutatakse harva, mistõttu neile pühendatud masinaressursid raisatakse suures osas.
  • Harva kasutatavate keerukate käskude täitmiseks eraldatud masinaressursse on parem kasutada lihtsamate ja sagedamini kasutatavate käskude täitmise kiirendamiseks.
  • Komplekssed mikrokodeeritud juhised võivad vajada palju erinevaid kella tsükleid ja neid on jõudluse suurendamiseks keeruline toru abil juhtida.

On ka vastuväiteid:

  • Tugevalt mikrokooditud rakenduste keerukad juhised ei pruugi vajada palju lisamasina ressursse, välja arvatud mikrokoodi ruum. Näiteks kasutatakse sama ALU-d sageli efektiivse aadressi arvutamiseks ja operandide tulemuse arvutamiseks, nt algsed Z80, 8086 ja teised.
  • Lihtsamaid mitte-RISC-käsklusi (st otsemälu operande hõlmavaid käske) kasutavad tänapäevased kompilaatorid sageli. Isegi otsest pinu tegemist (st mälutulemust) teostavaid aritmeetilisi tehteid kasutatakse tavaliselt. Kuigi selliseid mäluoperatsioone, sageli erineva pikkusega kodeeringutega, on keerulisem torujuhtmena juhtida, on see siiski täiesti teostatav - ilmekaks näiteks on i486, AMD K5, Cyrix 6x86, Motorola 68040 jne.
  • Mitte-RISC käsud teevad oma olemuselt käsu kohta rohkem tööd (keskmiselt) ja on tavaliselt ka väga kodeeritud, seega võimaldavad need sama programmi väiksemat kogumahtu ja seega piiratud vahemälu paremat kasutamist.

Paljud RISC- ja VLIW -protsessorid on loodud iga käsu (kui see on vahemälus) täitmiseks ühe tsükli jooksul. See on väga sarnane sellele, kuidas mikrokoodiga protsessorid täidavad ühe mikroinstruktsiooni tsükli kohta. VLIW protsessoritel on juhised, mis käituvad sarnaselt väga laia horisontaalse mikrokoodiga, kuigi tavaliselt puudub neil selline peenhäälestatud kontroll riistvara üle nagu mikrokoodil. RISC-käsud on mõnikord sarnased kitsa vertikaalse mikrokoodiga.

Mikrokood on olnud populaarne rakenduspõhistes protsessorites, näiteks võrguprotsessorites, digitaalsignaaliprotsessorites, kanalikontrollerites, kettakontrollerites, võrguliidese kontrollerites, välkmälu kontrollerites, graafikaprotsessorites ja muus riistvaras.

Mikrooperatsioonid

[muuda | muuda lähteteksti]

Kaasaegsed CISC implementatsioonid, näiteks x86 perekond alates NexGen Nx586-st, Intel Pentium Pro ja AMD K5-st, dekodeerivad käsud dünaamiliselt puhverdatud mikrooperatsioonideks, kasutades RISC-i või traditsioonilise mikrokoodiga sarnast käskude kodeeringut. Juhtmega ühendatud käskude dekodeerimisüksus väljastab otse mikrooperatsioone tavaliste x86 käskude jaoks, kuid keerukamate või harva kasutatavate käskude jaoks kasutab see traditsioonilisemat mikrokoodi ROM-i, mis sisaldab mikrooperatsioone.

Näiteks võib x86 otsida mikrokoodist mikrooperatsioone, et käsitleda keerulisi mitmeastmelisi operatsioone, nagu tsükli- või stringikäsud, ujukomaühiku transtsendentaalsed funktsioonid või ebatavalised väärtused, näiteks ebanormaalsed arvud, ja eriotstarbelised käsud, näiteks CPUID .

  1. IBM horizontally microcoded processors had multiple micro-orders and register select fields that required decoding.
  1. 1,0 1,1 1,2 Kent, Allen; Williams, James G. (5. aprill 1993). Encyclopedia of Computer Science and Technology: Volume 28 - Supplement 13. New York: Marcel Dekker, Inc. ISBN 0-8247-2281-7. Originaali arhiivikoopia seisuga 20. november 2016. Vaadatud 17. jaanuaril 2016.
  2. Fog, Agner (2. mai 2017). The microarchitecture of Intel, AMD and VIA CPUs (PDF) (Report). Technical University of Denmark. Originaali arhiivikoopia (PDF) seisuga 28. märts 2017. Vaadatud 21. augustil 2024.
  3. "IBM pSeries Servers - Microcode Update for Ultrastar 73LZX (US73) 18/36 GB". IBM. Originaali arhiivikoopia seisuga 19. aprill 2019. Vaadatud 22. jaanuaril 2015.
  4. 4,0 4,1 Both, David (23. juuli 2020). "The central processing unit (CPU): Its components and functionality". Red Hat. Viitamistõrge: Vigane <ref>-silt; nime "CPU" on määratud mitu korda erineva sisuga.
  5. Pickens, John. "NMOS 6502 Opcodes". 6502.org.
  6. 6,0 6,1 Shirriff, Ken. "How the 8086 processor's microcode engine works". Ken Shirriff's blog.
  7. "ISO/IEC/IEEE 24765:2017(en) Systems and software engineering — Vocabulary". www.iso.org. Vaadatud 23. juunil 2024.
  8. VAX 9000 System Technical Description (PDF). Digital Equipment Corporation. Mai 1990. Lk 3 -- 5-3 -- 32. EK-KA90S-TD-001.
  9. VAX 8800 System Technical Description Volume 2 (PDF). Digital Equipment Corporation. Juuli 1986. EK-KA882-TD-PRE.
  10. Manning, B.M.; Mitby, J.S; Nicholson, J.O. (november 1979). "Microprogrammed Processor Having PLA Control Store". IBM Technical Disclosure Bulletin. 22 (6). Originaali arhiivikoopia seisuga 1. oktoober 2012. Vaadatud 10. juulil 2011.
  11. Often denoted a ROM/PLA control store in the context of usage in a CPU; Supnik, Bob (24. veebruar 2008). "J-11: DEC's fourth and last PDP-11 microprocessor design ... features ... ROM/PLA control store". Originaali arhiivikoopia seisuga 9. juuli 2011. Vaadatud 10. juulil 2011.
  12. "6502 Images". Originaali arhiivikoopia seisuga 4. märts 2016. Vaadatud 22. jaanuaril 2015.
  13. IBM System/360 Model 50 Functional Characteristics (PDF). IBM. 1967. Lk 7. A22-6898-1. Vaadatud 29. oktoobril 2021.
  14. 14,0 14,1 Shirriff, Ken. "Simulating the IBM 360/50 mainframe from its microcode". Ken Shirriff's blog.
  15. Supnik, Bob (mai 1988). VLSI VAX Micro-Architecture (PDF). Digital Equipment.
  16. 16,0 16,1 Cocke, John; Markstein, Victoria (jaanuar 1990). "The evolution of RISC technology at IBM" (PDF). IBM Journal of Research and Development. 34 (1): 4–11. DOI:10.1147/rd.341.0004.
  17. 17,0 17,1 Clark, Douglas; Strecker, William (september 1980). "Comments on "The Case for the Reduced Instruction Computer"". ACM. 8 (6): 34–38. DOI:10.1145/641914.641918.
  18. "Pentium Pro Processor At 150, 166, 180, and 200 MHz" (PDF) (Datasheet). Intel. November 1995.
  19. 19,0 19,1 "Part I / Common Architecture, Chapter 6 Common PALcode Architecture". Alpha AXP Architecture Reference Manual (PDF) (Second ed.). Digital Press. 1995. ISBN 1-55558-145-5.
  20. Rogers, Bob (september–oktoober 2012). "The What and Why of zEnterprise Millicode". IBM Systems Magazine. Originaali arhiivikoopia seisuga 9. oktoober 2012.
  21. "EMIDEC 1100 computer". Emidec.org.uk. Originaali arhiivikoopia seisuga 12. juuni 2010. Vaadatud 26. aprillil 2010.
  22. IBM System/360 Model 25 Functional Characteristics (PDF). IBM. Jaanuar 1968. Lk 22. A24-3510-0. Vaadatud 29. oktoobril 2021.
  23. 23,0 23,1 23,2 Field Engineering Theory of Operation, 2030 Processing Unit, System/360 Model 30 (PDF) (First ed.). IBM. Juuni 1967. Y24-3360-1. Originaali (PDF) arhiivikoopia seisuga 1. aprill 2020. Vaadatud 9. novembril 2019.
  24. Edward A. Snow; Daniel P. Siewiorek (1982). "Implementation and Performance Evaluation of the PDP-11 Family". Daniel P. Siewiorek; C. Gordon Bell; Allen Newell (toim-d). Computer Structures: Principles and Examples. New York, NY: McGraw-Hill Book Company. Lk 671. ISBN 0-07-057302-6.
  25. Soltis, Frank (september 1981). "Design of a Small Business Data Processing System". IEEE Computer. 14: 77–93. DOI:10.1109/C-M.1981.220610.
  26. Frank G. Soltis (1997). Inside the AS/400, Second Edition. Duke Press. ISBN 978-1882419661.
  27. "Interview: Battling the N64 (Naboo)". IGN64. 10. november 2000. Originaali arhiivikoopia seisuga 13. september 2007. Vaadatud 27. märtsil 2008.
  28. "Indiana Jones and the Infernal Machine". IGN. 12. detsember 2000. Originaali arhiivikoopia seisuga 27. september 2013. Vaadatud 24. septembril 2013.
  29. Meynink, Todd (28. juuli 2000). "Postmortem: Angel Studios' Resident Evil 2 (N64 Version)". Gamasutra. United Business Media LLC. Originaali arhiivikoopia seisuga 21. oktoober 2012. Vaadatud 18. oktoobril 2010.
  30. Digital Scientific Meta 4 Series 16 Computer System Reference Manual (PDF). Digital Scientific Corporation. Mai 1971. 7032MO. Originaali (PDF) arhiivikoopia seisuga 14. jaanuar 2020. Vaadatud 14. jaanuaril 2020.
  31. Digital Scientific Meta 4 Computer System Read-Only Memory (ROM) Reference Manual (PDF). Digital Scientific Corporation. Märts 1970. 7024MO. Originaali (PDF) arhiivikoopia seisuga 23. september 2019. Vaadatud 14. jaanuaril 2020.
  32. The Digital Scientific Meta 4 Series 16 Computer System Preliminary System Manual (PDF). Digital Scientific Corporation. Juuni 1970. 7006MO. Originaali (PDF) arhiivikoopia seisuga 23. september 2019. Vaadatud 14. jaanuaril 2020.
  33. Digital Scientific Meta 4 Computer System Typical ROM Pattern Listing and Program To Simulate The IBM 1130 Instruction Set (PDF). Digital Scientific Corporation. Jaanuar 1970. M4/005P-170. Originaali (PDF) arhiivikoopia seisuga 24. märts 2020. Vaadatud 14. jaanuaril 2020.
  34. "Western Digital 1600". AntiqueTech. Originaali arhiivikoopia seisuga 3. jaanuar 2017. Vaadatud 5. jaanuaril 2017.
  35. Hayes, John P. (1978). Computer Architecture and Organization. McGraw-Hill. Lk 300. ISBN 0-07-027363-4.
  36. Neal Harman; Andy Gimblett (12. oktoober 2009). "CS-323: High Performance Microprocessors – Chapter 1. Microprogramming". mat.uson.mx. Originaali arhiivikoopia seisuga 19. aprill 2015. Vaadatud 8. augustil 2015.
  37. Vaupel, Robert (2013). High Availability and Scalability of Mainframe Environments using System z and z/OS as example. KIT Scientific. Lk 26. ISBN 978-3-7315-0022-3.
  38. Rogers, Bob (september–oktoober 2012). "The What and Why of zEnterprise Millicode". IBM Systems Magazine. Originaali arhiivikoopia seisuga 16. oktoober 2013. Vaadatud 7. novembril 2013.
  39. "PALcode for Alpha Microprocessors System Design Guide" (PDF). Digital Equipment Corporation. Mai 1996. Originaali (PDF) arhiivikoopia seisuga 15. august 2011. Vaadatud 7. novembril 2013.
  40. Spruth, Wilhelm (detsember 2012). The Design of a Microprocessor. Springer Science & Business Media. Lk 31. ISBN 978-3-642-74916-2. Originaali arhiivikoopia seisuga 20. november 2016. Vaadatud 18. jaanuaril 2015.
  41. Koopman, Philip Jr. (1987). "Writable instruction set, stack oriented computers: The WISC Concept" (PDF). The Journal of Forth Application and Research: 49–71. Originaali (PDF) arhiivikoopia seisuga 11. mai 2008.
  42. Smotherman, Mark. "CPSC 3300 / The Soul of a New Machine". Vaadatud 27. oktoobril 2023. 4096 x 75-bit SRAM writable control store: 74-bit microinstruction with 1 parity bit (18 fields)
  43. IBM System/370 Principles of Operation (PDF). Fourth Edition. IBM. September 1974. Lk 98, 245. GA22-7000-4. Originaali (PDF) arhiivikoopia seisuga 29. veebruar 2012. Vaadatud 27. augustil 2012.
  44. IBM System/360 Model 85 Functional Characteristics (PDF). SECOND EDITION. IBM. Juuni 1968. A22-6916-1. Vaadatud 29. oktoobril 2021.
  45. IBM System/360 Special Feature Description 709/7090/7094 Compatibility Feature for IBM System/360 Model 85. First Edition. IBM. Märts 1969. GA27-2733-0.
  46. "9.11: Microcode update facilities". Intel 64 and IA-32 Architectures Software Developer's Manual, Volume 3A: System Programming Guide, Part 1 (PDF). Intel. September 2016.
  47. "Download Linux* Processor Microcode Data File". Originaali arhiivikoopia seisuga 19. märts 2018. Vaadatud 21. märtsil 2018.
  48. "Intel Microcode Update Utility for Linux". Originaali arhiivikoopia seisuga 26. veebruar 2012.
  49. "[ports] Index of /head/sysutils/cpupdate". Freebsd.org. Originaali arhiivikoopia seisuga 1. aprill 2020. Vaadatud 16. jaanuaril 2020.
  50. "A microcode reliability update is available that improves the reliability of systems that use Intel processors". Originaali arhiivikoopia seisuga 23. veebruar 2008. Vaadatud 25. veebruaril 2008.
  51. "Server Products - BIOS Update required when Missing Microcode message is seen during POST". Intel. 24. jaanuar 2013. Originaali arhiivikoopia seisuga 1. september 2014.
  52. "Model 990/12 LR Computer Depot Maintenance and Repair Manual" (PDF). Bitsavers.org. Texas Instruments. Vaadatud 15. veebruaril 2024.
  53. Texas Instruments Model 990 Computer MDS-990 Microcode Development System Programmer's Guide (15 August 1979 ed.). Texas Instruments Archives, RG-20 accession 94-08, Box 10, 45C. DeGolyer Library, Southern Methodist University, Dallas, TX USA.{{cite book}}: CS1 hooldus: koht sisaldab numbrit (link)

Lisalugemist

[muuda | muuda lähteteksti]

Välislingid

[muuda | muuda lähteteksti]