IA-64 (engl. Intel Architecture 64, Itanium) on Intelin ja Hewlett-Packardin yhteistyössä kehittämä 64-bittinen suoritinarkkitehtuuri, jota Intelin Itanium -perheen suorittimet käyttivät. Sen käskykanta muistuttaa VLIW-suunnitteluperiaatetta, joka käytännössä tarkoittaa sitä, että käskyt koostuvat useammasta rinnakkaisesta RISC-tyylisestä käskystä, mutta IA-64 ei mene äärimmäisyyksiin VLIW-periaatteen seuraamisessa vaan sisältää kompromisseja RISCin suuntaan.

IA-64
Perustietoja
Kehittäjä Intel
Valmistaja Intel
Arkkitehtuuri ja luokitus
Osoiteavaruus 64-bit

IA-64 tarkoitettiin korvaamaan 64-bittisiä RISC-arkkitehtuureita, kuten HP:n PA-RISC ja SGI:n MIPS-arkkitehtuuri. Tämä tarkoitti vähintään kaikkien ohjelmien kääntämistä uudelleen. Vuonna 2006 HP, NEC, Hitachi, SGI ja Fujitsu ilmoittivat sijoittavansa yhteensopivien koneiden kehittämiseen 10 miljardia dollaria vuoteen 2010 mennessä.[1]Suorittimen myöhästyminen useita vuosia ja alun suorituskykyongelmat tekivät Itaniumista teollisuuden naurunaiheen ja se sai lempinimen "Itanic" Titanic-laivaan viitaten.[1]

Intel tarkoitti IA-64:n jossain vaiheessa myös korvaamaan PC-koneissa käytetty x86-arkkitehtuuri. IA-64 soveltuu tähän huonosti, koska PC-maailmassa käytettyä IA-32-koodia pitäisi ajaa emuloimalla, mistä syystä useimmat 64-bittisyyttä kaipaavat PC-käyttäjät ovat valinneet mieluummin AMD:n 64-bittisen ratkaisun, AMD64:n.

IA-64:ssä on huomattavasti vaikutteita HP:n PA-RISC-arkkitehtuurista, ja se pystyy suorittamaan vanhaa PA-RISC-koodia ohjelmallisella emulaatiolla ilman kovinkaan suurta nopeushävikkiä. Ohjelmallinen PA-RISC-emulaattori on kaikissa IA-64:ää tukevissa HP-UX:n versioissa.

Kymmenen vuotta Itaniumin julkaisun jälkeen 95 % sitä käyttävistä myydyistä koneista oli HP:n palvelimia ja 3 % NEC:in. SGI sen sijaan ajautui konkurssiin.[1] Vuonna 2015 Hewlett-Packard on ainoa jäljellä oleva Intelin kumppani, joka käyttää IA64-alusta suorittimia.[2]

Toukokuussa 2017 julkaistu Itanium 9700, koodinimeltään Kittson jäi viimeiseksi Itanium-suorittimeksi.[3]

Käskykannan ominaisuuksia muokkaa

Käskyjen niputus muokkaa

IA64-käskykannassa jokainen käskysana (bundle) voi sisältää kolme operaatiota.

Useampi käskysana voidaan niputtaa yhteen yhdeksi käskyjoukoksi, jos näiden välillä ei ole riippuvuuksia, ja tällöin nämä saadaan suorittaa rinnakkain, jos suoritin kykenee suorittamaan useamman käskysanan kellojaksossa. Tieto niputuksesta on tallennettu käskysanoihin. Tässä mielessä IA64 ei ole täysin puhdas VLIW, koska samassa kellojaksossa voidaan suorittaa useampia käskysanoja, ja käskysanat voivat sisältää verrattaen pienen määrän käskyjä.

Syy tähän kompromissiin lienee mahdollisuus tehdä myöhemmin tehokkaampia samaa konekielikoodia ajavaa koodia; puhdas VLIW jossa käskysanassa olisi aina kaikki rinnakkain ajettavat käskyt löisi lukkoon myös prosessorin suoritinyksiköiden määrän ja siten ei mahdollistaisi samaa konekielikoodia nopeammin ajavia uusia suoritinmalleja; IA64-käskykanta taas mahdollistaa useampia käskysanoja rinnakkain ajavien suorittimien tekemisen.

Kaikki markkinoille tulleet Itanium-mallit ovat pystyneet suorittamaan kaksi käskysanaa eli maksimissaan 6 operaatiota kellojaksossa.

Rekisterien pyöritys muokkaa

Käskykanta määrittelee käskyt rekisterien uudelleennimeämiseen. Ylimpiä 3/4 rekistereistä käytetään uudelleennimeämismekanismin kautta. Uudelleennimeäminen perustuu indeksien pyöritykseen; jos rekisteri-indeksiä on pyöritetty kahden verran, tarkoittaa se sitä, että käsky joka näennäisesti osoittaa kokonaislukurekisteriin 32 osoittaakin oikeasti rekisteriin 34. Ylimpään rekisteriin 127 osoittava viite pyörähtää ympäri osoittamaan rekisteriin 33.

Rekisterien pyöritys mahdollistaa esimerkiksi nopeammat funktiokutsut; rekistereitä pyörittämällä voidaan haluttu toisissa rekistereissä oleva data saada näkyviin kutsuttavan funktion sisään tulevina parametrirekistereinä siirtämättä itse dataa.

Rekisterien automaattinen talletus muokkaa

Jos rekistereitä tarvitaan enemmän kuin niitä on aikaisempien pyöritysten jälkeen vapaana, prosessori osaa itse automaattisesti tallettaa rekistereitä pinoon.

Ehdolliset käskyt ja predikaattirekisterit muokkaa

IA-64-koodissa pyritään mahdollisimman suuri osa haarautumisista poistamaan ehdollisten käskyjen avulla. Prosessorilla on 64 1-bittistä predikaattorekisteriä, joihin voidaan tallettaa vertailuoperaatioiden tuloksia. Käskysanoissa voidaan määritellä, että operaatio suoritetaan jos tietty ehtorekisteri on tosi tai epätosi.

Käyttöjärjestelmätuki muokkaa

  • HP-UX
  • OpenVMS
  • Linux. Linux-ytimen versio 6.7 poisti tuen IA-64-käskykannalta marraskuussa 2023. Täten viimeiseksi sitä tukevaksi versioksi jäi pitkään tuettu (LTS) versio Linux 6.6 LTS.[4]

Lähteet muokkaa

  1. a b c Ashlee Vance: Ten Years After First Delay, Intel's Itanium Is Still Late Bits Blog. 9.2.2009. Viitattu 7.1.2024. (englanniksi)
  2. Intel still committed to make new Itanium processors KitGuru. Viitattu 19.1.2017.
  3. Intel's Itanium, once destined to replace x86 processors in PCs, hits end of line 11.5.2017. PC World. Viitattu 5.7.2017.
  4. Intel Itanium IA-64 Support Removed With The Linux 6.7 Kernel www.phoronix.com. Viitattu 7.1.2024. (englanniksi)