RISC-V on kärbitud käsustik (RISC), mida hakati arendama 2010. aastal. [1] RISC-V on avatud standard ning selle spetsifikatsioon on avalikult saadaval vastavalt Creative Commons litsentsile.[2] Käsustiku litsents lubab igaühel luua implementatsiooni ilma litsentsitasu maksmata, ka ärieesmärgil.[3] Käsustikku arendab RISC-V Foundation.[1]
RISC-V sai alguse USA California Ülikooli Berkeleys paralleelsete arvutuste laboris, kus Krste Asanović, Yunsup Lee ja Andrew Waterman alustasid 2010. aastal vaba käsustiku arendamise projekti. 13. mail 2011 avaldati esimene RISC-V-d käsitlev publikatsioon. Samal aastal tehti esimene RISC-V kiibi disain.
2015. aastal loodi sihtasutus RISC-V Foundation käsustiku edasiseks arendamiseks. Alates 2018. aastast teeb RISC-V Foundation koostööd Linux Foundationiga.[1]
RISC-V käsustiku disain on modulaarne, st implementatsiooni loojad saavad valida, millised käsuhulgad on tarvis realiseerida: kas ainult baaskäskude hulk või lisada ka lisakäsud. See potentsiaalselt võimaldab RISC-V kasutada seadete loomiseks alates mikrokontrolleritest kuni superarvutiteni.
RISC-V võimaldab kuni 128-bitise mälu adresseerimist.[5] Üks RISC-V riistvaraline lõim omab mäluaadressiruumi suurusega 2n baiti, kus n on täisarvu registri suurus bittides (nt 32-bitises mäluaadressiruumis on registri suurus 32 bitti). Mäluaadressiruum on n-ö ringkujuline ehk aadressis 2n-1 asuv bait külgneb aadressil 0 asuva baitiga.
Iga käsu täitmine toob kaasa ühe või rohkem mällupöördumist. Mällupöördumine võib olla kas kaudne (implicit) või ilmne (explicit). Kaudse mällupöördumise puhul sooritatakse mälust lugemise operatsioon käsu aadressi äratoomiseks (instuction fetch). Ilmse mällupöördumise puhul sooritatakse kas lugemise või kirjutamise operatsiooni käsus määratud mäluaadressil.
RISC-V saab käsitleda mitte ühte käsustikuna, vaid nelja baaskäsustikkude perekonnana:[2]
RV32I (32-bitine mäluaadressiruum)
RV64I (64-bitine mäluaadressiruum)
RV32E (RV32I lihtsustatud variant mikrokontrollerite jaoks, registrite arv on kaks korda väiksem RV32I-ga võrreldes)
RV128I (128-bitine mäluaadressiruum)
Iga RISC-V implementatsioon peab realiseerima mingit baaskäsustikku. Peale baaskäske on olemas ka muud käskude hulgad, mida nimetatakse laiendusteks. Sellised laiendused sisaldavad käske lisafunktsionaalsuse realiseerimiseks. Näiteks kui implementatsioon kasutab RV32I käsustikku, siis sellele implementatsioonile saab lisada järgnevaid laiendusi:
Nende laienduste kogumi koos baaskäsustikuga nimetatakse RV32G. Laiendused teiste baaskäsustikkude jaoks on nimetatud samal moel nagu eeltoodud näites: viimane täht tähendab millise funktsionaalsuse realiseerimiseks seda käsustikku kasutatakse (nt 64-bitise mäluaadressiruumiga käsustik korrutamise ja jagamise käskude jaoks on nimetatud RV64M jne).[2][6]
RISC-V käsud on väga lühikesed.[5] Baaskäsud on 32-bitised ning peavad olema joondutud 32 biti piiris. RISC-V toetab ka käske, milliste pikkus on 16*n biti (n on positiivne täisarv). Kui tegemist on 16-bitiste käskudega siis joondus on 16 bitti, vastasel juhul on see tavaliselt 32 bitti. RISC-V implementatsiooni maksimaalne käsu pikkus on võrdne positiivse täisarvuga korrutatud joondusega ning sõltub sellest milliseid käskude hulki (baaskäsud koos laiendustega) implementatsioon realiseerib.
Sõltuvalt käsu pikkusest omavad käsu vähima kaaludega bitid erinevaid kindlaid väärtusi:
16-bitiste käskude puhul 2 vähima kaaludega bittide väärtused saavad olla kas 00, 01, 10, kuid mitte 11
32-bitiste käskude puhul 2 vähima kaaludega bittide väärtused on alati 11; järgmiste suurema kaaludega bittide väärtused ei saa olla 111
48-bitiste käskude puhul 6 vähima kaaludega bittide väärtused on alati 011111
64-bitiste käskude puhul 7 vähima kaaludega bittide väärtused on alati 0111111
kui käskude pikkus on 80 bitti või rohkem kuid vähem kui 192 bitti, siis 16 vähima kaaludega bittide väärtused on xnnnxxxxx1111111, kus nnn = (käskude pikkus – 80)/16 binaarkujul
kui käskude pikkus on 192 bitti, siis 16 vähima kaaludega bitride väärtused on x111xxxxx1111111
Käskude üldkuju on KÄSK rd[a], operand1, operand2. Näiteks kui sooritatakse operatsiooni registri väärtuse ja otsese väärtuse peale, siis käsu kuju on KÄSK rd, rs1[b], imm.
ADDI: liidab otsest väärtust ja rs1 registri väärtust
SLTI/SLTIU: võrdleb rs1 registri väärtus ja otsest väärtust; kui rs1 väärtus on vähem kui otsene väärtus sihiregistrile pannakse 1, vastasel juhul sihiregistrile pannakse 0
SLT/SLTU: võrdleb rs1 registri ja rs2 registri väärtusi; kui rs1 väärtus on vähem kui rs2 väärtus sihiregistrile pannakse 1, vastasel juhul sihiregistrile pannakse 0
Load käsk sooritab andmete ülekannet mälust registrisse. Store käsk sooritab andmete ülekannet registrist mällu. Load on I-tüüpi formaadi käsk; Store on S[e]-tüüpi formaadi käsk.
RISC-V saab toetada erinevaid tarkvaravirnu, mis võimaldavad implementeerida privilegeeritud täitmist. On olemas 3 täitmise keskkonna (execution environment) tüüpi:
AEE[f] (rakenduse täitmise keskkond): käivitab ainult ühte rakendust, mis on kodeeritud kindla binaarse rakendusliidesega täitmiseks. Binaarne rakendusliides on siin täitmise keskkonna ja rakenduse vahendajaks: rakendus ei tööta täitmise keskkonnaga otseselt, vaid binaarse rakendusliidese kaudu. Sellisel juhul töötab implementatsioonil samaaegselt ainult üks rakendus.
SEE[g] (superviisori täitmise keskkond): käivitab operatsioonisüsteemi binaarse superviisorliidese kaudu. Operatsioonisüsteem omakorda käivitab rakendusi binaarse rakendusliidese kaudu. Sellisel juhul töötab implementatsioonil samaaegselt üks operatsioonisüsteem, mis saab käivitada ühte või mitut rakendusi.
HEE[h] (hüperviisori täitmise keskkond): käivitab hüperviisori binaarse hüperviisorliidese kaudu. Hüperviisor omakorda käivitab operatsioonisüsteeme binaarse superviisorliidese kaudu, milled saavad käivitada rakendusi binaarse rakendusliidese kaudu. Sellisel juhul saavad implementatsioonil töötada mitut operatsioonisüsteeme.
Iga RISC-V riistvaraline lõim töötab mingisugusel hetkel mingi privileegitasemel, mis on määratud kontroll- ja staatusregistrites. Kokku on olemas 3 privileegitaset: U (User/Application; Kasutaja/Rakendus); S (Supervisor; Superviisor); M (Machine; Masin). Mõned käsud on võimalik sooritada ainult juhul, kui riistvaraline lõim töötab mingil privileegitasemel. Kui proovitakse sooritada mingit käsku, mis ei saa sooritada jooksva privileegitasemel, siis visatakse erindit.[7]
Ülalpool kirjeldatud käsud saab RISC-V implementatsioon täita olenemata sellest milles privileegitasemel antud implementatsioon töötab.[2]
↑Chen, Tony; Patterson, David A. (26. jaanuar 2016). "RISC-V Geneology"(PDF) (inglise keeles). Berkeley: University of California at Berkeley. Originaali(pdf) arhiivikoopia seisuga 13.07.2019. Vaadatud 27.04.2020.{{netiviide}}: CS1 hooldus: mitu nime: autorite loend (link) CS1 hooldus: tundmatu keel (link)