Mikro-ohjelma tai mikrokoodi on osassa suorittimia käytetty suorittimen sisäinen ohjelma, jonka avulla varsinaiset konekielen käskyt on toteutettu.

Historia

Varhainen mikro-ohjelman käyttökohde oli IBM S/360, jossa sen avulla toteutettiin taaksepäin yhteensopivuus aiempien mallien kuten suositun IBM 1401:n kanssa.[1] Mikrokoodista tuli suosittua prosessoreissa 1970-luvun jälkipuoliskolta lähtien.[2]

Varhaiset mikroprosessorit kuten MOS 6502 ja Z-80 eivät käytä mikrokoodia, mutta Intel 8086 ja Motorola 68000 käyttävät jo. 8086 toteuttaa mikrokoodilla esimerkiksi kerto- ja jakolaskut.[3]

Intel on käyttänyt x86-sarjan P6-suorittimista lähtien mikrokoodia, joka voidaan päivittää ohjelmallisesti suorittimen virheiden korjaamiseksi.[4] Muun muassa Linux-, Solaris- ja Windows-käyttöjärjestelmät sisältävät ajuritukea mikrokoodin päivittämiseen ilman BIOSin päivitystä.[5]

Modernit Intelin, AMD:n ja ARMin suorittimet purkavat käskyt mikro-operaatioiksi.[6][7]

Mikro-ohjelman piirteitä

Mikro-ohjelmalle on tyypillistä pitkät käskysanat, joiden bitit ohjaavat suoraan suorittimen sisäisiä toimintoja.[8] Mikro-ohjelmalle näkyvät suorittimen eri toimiyksiköt, kuten rekisterit tai akut, väylät, liukuhihnat, aritmeettis-looginen yksikkö ja niin edelleen. Tästä seuraa se, että ohjelman abstraktiotaso on erittäin matala, mutta hyvä ohjelmoija pystyy käyttämään suorittimen sisäistä rinnakkaisuutta hyväkseen.

Mikro-ohjelmat olivat aiemminlähde? erittäin yleisiä niin sanotuissa CISC-tyyppisissä koneissa, joissa käskyt ja osoitusmuodot olivat monimutkaisia. Näiden taas tuli olla monimutkaisia, jotta pieneen keskusmuistiin mahtuisi koko tarvittava ohjelma. RISC-arkkitehtuuri toi mukanaan ajatuksen, että käskyjen tulee olla yksinkertaisia.

Tyypillisesti pienet suorittimet eivät ole mikro-ohjelmoituja tai vain hankalimmat käskyt on toteutettu mikro-ohjelmalla. Mitä monimutkaisempi suoritin, sitä todennäköisemmin sen toteutuksessa on hyödynnetty myös mikro-ohjelmaa.

Samankaltaisia lähestymistapoja

Erityistarkoituksiin on suunniteltu koneita, joissa ei ole varsinaisia konekäskyjä, vaan niitä ohjelmoidaan samaan tapaan kuin mikro-ohjelmaa. Tällainen laite oli esimerkiksi FPS-164. [9][10] Myöhemmin on kehitetty leveän käskysanan (VLIW) arkkitehtuuri, jossa käskysanan eri osat sisältävät eri toimilohkojen konekäskyjä. Leveällä käskysanalla päästään suorittimen sisäisen rinnakkaisuuden hyödyntämiseen, mutta ohjaus ei ole niin yksityiskohtaista kuin varsinaisessa mikro-ohjelmassa.

Mikro-ohjelman muokattavuudesta

Mikro-ohjelma on tavallisesti ollut kiinteä, eli sitä ei ole voinut vaihtaa. Alun perin sanalla firmware tarkoitettiinkin lähinnä mikro-ohjelmaa.lähde? Toisaalta osa koneista (Burroughs B1700 ja sen sukulaiset[11][12]) mahdollisti jopa sen, että prosessinvaihdon yhteydessä vaihdettiin myös mikro-ohjelma. Näin voitiin tehdä eri ohjelmointikielille niille sopivin käskykanta. Myös mikro-ohjelmakääntäjiä on olemassa.

Lähteet

Kirjallisuutta

Aiheesta muualla

Wikiwand in your browser!

Seamless Wikipedia browsing. On steroids.

Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.

Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.