Milli arhitektuur

Milli arhitektuur (inglise keeles Mill architecture) on uudne üldotsarbelise protsessori arhitektuur, mis on väljatöötamisel Mill Computing, Inc. poolt.[1] Mill on vööarvuti (ingl. Belt machine), mis erineb pinu- ja registripõhilistest arvutitest.[2] Vööprotsessoris puuduvad üldotstarbelised registrid, ning nende asemel on kasutusel nn. registrite vöö (ingl. belt).[3] Vöö kasutamine võimaldab suurendada protsessori efektiivsust, võrreldes x86 ja PowerPC arhitektuuridega, eemaldades suure hulga energiakulukaid ümbernimetusregistreid. x86 ja PowerPC protsessorites on umbes pool kasutatavast elektrienergiast ümbernimetusregistrite jaoks.[4] Milli kavatsetud otstarbeks on olla konkurendiks x86 ja ARM protsessoritele, kuigi 2020. aasta alguse seisuga ühtegi Milli protsessorit füüsilisel kujul veel ei eksisteeri.[4][5]

Ajalugu muuda

2003. veebruaris alustasid endised Philips Trimedia signaaliprotsessorite arhitektuurimeeskonna liikmed koos Ivan Godardiga Milli arhitektuuri loomist.[1][5][6]

2004. jaanuaris panid Milli arhitektuuri loojad oma ühingu nimeks Out-of-the-Box Computing.[1]

2014. märtsis inkorporeeris Out-of-the-Box computing ennast Mill Computing, Inc. nime all.[1][5]

Vöö muuda

 
Vöölt väärtuste lugemine, summeerimine ja tulemuse vööle kirjutamine.

Registrite vöö töötab FIFO või üldisemalt konveierlindi põhimõttel. Vööl olevaid andmeid saab lugeda igalt positsioonilt, kuid uusi väärtuseid saab kirjutada ainult vöö algusesse. Uue väärtuse vööle kirjutamisega liiguvad kõik olemasolevad väärtused ühe koha võrra edasi. Kuna vööl on kindel pikkus siis sellest välja liikunud väärtused kustuvad.[5] Vöö pikkus on 8, 16, 32 registrit olenevalt protsessori implementatsioonist.[7] Vöö on abstraktsioon, mis sarnaneb nihkeregistriga, tegelikkuses riistvaralist nihkeregistrit protsessori ehituses kasutusel ei ole.[3]

Andmed mida läheb vaja hiljem kui vööpikkus seda lubab, saab kirjutada eraldi vahemällu, mida Milli arhitektuuris kutsutakse märkmikuks (ingl. scratchpad). Igal programmil ja alamprogrammil on enda isiklik vöö ja märkmik. Alamprogrammi sisendväärtused paigutatase tema vööle. Kui alamprogrammi sisendid on liiga suured või neid on kokku rohkem kui vööl pikkust on, siis tuleb neid eraldi mälust lugeda. Alamprogrammi lõpetamisel paigutatakse tagastatavad väärtused väljakutsuva programmi vööle, alamprogrammil endal väljakutsuva programmi vööle ega märkmikule ligipääsu ei ole.

Sama tsükli jooksul saab mitu käsku vöölt väärtusi lugeda. Kui vööle on sama tsükli jooksul vaja kirjutada mitut väärtust, siis need kirjutatakse väljakutsumise järjekorras s.t esimesena käivitatud käsk või alamprogramm paigutab enda tulemuse vööle esimesena. Milli arhitektuur toetab mitme väärtuse tagastamist ühest käsust või alamprogrammist.[7]

Käsustik ja toru muuda

 
Pikk käsu sõne

Mill on laia käsustikuga arhitektuur ning kasutab pikki käsu sõnesid (ingl. very long instruction word) mis on kuni 33 individuaalset käsku pikad, millest iga käsk on kuni 15 bitti pikk. Käske käivitatakse kolmes faasis: lugemine, arvutamine, kirjutamine. Erinevate käskude täitmiseks läheb erinev arv tsükleid, nt. korrutamine võtab 3 tsüklit, liitmine aga 1 tsükli. Teineteisest sõltuvad käsud saavad olla samas torus ning eelneva käsu tulemus on järgneval käsul kohe kasutada, ilma seda väljundisse kirjutamata. Torude tööshoidmiseks on igas torus erinevate tsükliarvudega käsutäitmisüksused.[8] Suure hulga käskude dekodeerimiseks on kasutusel kaks käsu dekoodrit.[9]

Käsud on üldised ning saavad töötada erinevate andmesuurustega, näiteks sama summeerimiskäsk oskab summeerida nii baite kui ka ujukomaarve, või neid siis omavahel summeerida. Kõik käsud peale load käsu on kindla ette teatud ajaga, see võimaldab täiendavat koodi optimeerimist kompilaatori poolt.

Kõigil andmetel on protsessori siseselt olemas metaandmed, neid muutmällu kirjutades kaasa ei panda. Metaandmed võimaldavad hakkama saada ilma suure hulga käskudetta mis tegeleks nende väärtuste leidmise ja kontrollimisega. Metaandmeteks on skalaarsus, väärtuse suurus baitides, IEEE-754 ujukoma arvu puhul selle staatuslipud ja NaR-bitt (Not a Result). Tavapärases protsessoris salvestataks ujukoma arvu staatuslipud protsessori registritesse, seda võimalust milli puhul ei ole. NaR-bitti tähistab vigaseid andmeid ja seda kasutatakse spekulatiivsete käskude puhul valesti arvutatud väärtuse märgistamiseks. Mill toetab tarkvaralist spekulatiivset käskude käivitust kuid protsessor seda ise suvalises programmis ei tee.[10] Riistvaralise spekulatiivse käivituse puudumine teeb Milli protsessori immuunseks spectre, meltdown ja teiste sarnaste spekulatiivset käivitust kasutavate turvanõrkuste vastu.[11]

Käsustik toetab ka None väärtust, selleks on väärtus 0, millel on metaandmete NaR-bitt aktiivne. None väärtus tähistab olematut väärtust, ning seda store käsk põhimällu ei kirjutata.[10]

Mälu muuda

Milli protsessoris on eraldi L1-vahemälu käskudele ja andmetele, ning üks jagatud L2-vahemälu. Andmete vahemälu kasutab 9 bitti ühe baidi kohta, lisa bitt on kasutusel baidi valiidsuse jälgimiseks. Vahemälus olevad andmed võivad liikuda madalama taseme vahemällu. Vahemälust lugemisel loetakse vastavalt vajadusele andmeid igalt tasemelt, kui esimese taseme vahemälust loetakse baiti millel on valiidsusbitt mittevaliidne, siis otsitakse seda puuduvat väärtust ka teise taseme vahemälust.

Protsessori virtuaalne aadressiruum on 60-bitine, mille kõrged bitid on reserveeritud protsesside vaheliseks mälu isoleerimiseks. Turvalisuse tagamiseks tagastatakse initsialiseerimata mälust lugedes alati väärtus 0, see eemaldab ka vajaduse eraldi mälu nullida või vanu väärtuseid eemaldada.[12]

Viited muuda

  1. 1,0 1,1 1,2 1,3 "Who are we?". Vaadatud 08.05.2020.
  2. "You have a 50-year-old IBM mainframe in your pocket - a talk on a revolutionary computer architecture, Will Edwards (Mill Computing) on Dec 10, 2014". Vaadatud 08.05.2020.
  3. 3,0 3,1 Nico Ernst (26. mai 2014). "Startup will mit "Mill" Prozessorarchitektur revolutionieren". Vaadatud 08.05.2020.
  4. 4,0 4,1 "THE MILL CPU ARCHITECTURE". Vaadatud 08.05.2020.
  5. 5,0 5,1 5,2 5,3 Peter Clarke (12. jaanuar 2017). "Mill Computing heads to FPGA demo, seeks funds". Vaadatud 08.05.2020.
  6. "Mill CPU for Humans - Part 1". Vaadatud 08.05.2020.
  7. 7,0 7,1 "The Mill CPU Architecture - the Belt (2 of 13)". Vaadatud 08.05.2020.
  8. "Stanford Seminar -Drinking from the Firehose: How the Mill CPU Decodes 30+ Instructions per Cycle". Vaadatud 10.05.2020.
  9. Linley Gwennap (5. august 2013). [linleygroup.com/newsletters/newsletter_detail.php?num=5038 "Getting Way Out of the Box"]. Vaadatud 08.05.2020. {{netiviide}}: kontrolli parameetri |url= väärtust (juhend)
  10. 10,0 10,1 "The Mill CPU Architecture - Metadata (5 of 13)". Vaadatud 08.05.2020.
  11. "MILL VS. SPECTRE: PERFORMANCE AND SECURITY". Vaadatud 10.05.2020.
  12. "Memory". Vaadatud 08.05.2020.