Den här artikelnbehöverkällhänvisningar för att kunnaverifieras.(2020-12) Åtgärda genom att lägga till pålitliga källor (gärna som fotnoter). Uppgifter utan källhänvisning kanifrågasättas och tas bort utan att det behöver diskuteras pådiskussionssidan. |
Eninstruktionsuppsättning ellerISA (frånengelskansInstruction Set Architecture) beskriver vilka tillgångar som finns tillgängliga förprogrammeringen av enprocessor. Bland annat beskrivs de instruktioner,register,adresseringslägen,minnesarkitektur ochinterrupthantering (avbrottshantering) som processorn stöder. Instruktionsuppsättningen definierar även processornsmaskinkod, dvs hur instruktionerna blir uttryckta som sekvenser avbinära ettor och nollor.
Instruktionsuppsättningar kan skilja sig mellan processorer inte bara på grund av vilka operationer som stöds, utan även hur hämtning och lagring av värden iarbetsminnet stöds (CISC kontraRISC).
Två olika processorer kan ha samma instruktionsuppsättning även om de internt har helt olikamikroarkitekturer, se till exempelIntelsPentium- ochAMD:sAthlon-processorer.
Även om det är teoretiskt möjligt att konstruera en processor som endast har en slags instruktion, har de flesta vanliga processorer instruktioner av ett flertal olika typer.
Aritmetikinstruktioner utför operationer påheltal. Bland operationerna räknasaddition,subtraktion, logiska operationer somAND,OR, ochXOR, aritmetisk och logiskskiftning, m.fl.Multiplikation ochdivision förekommer ofta, men inte alltid eftersom dessa operation kan utföras avalgoritmer som använder sig av enklare additions- och subtraktionsinstruktioner.
Flyttalsinstruktioner utför operationer påflyttal. Bland operationerna finns addition, subtraktion, multiplikation, division, stöd för konvertering mellan heltal och flyttal, samt ibland även mer avancerade operationer somkvadratrot,trigonometriska funktioner m.m.
Vissa RISC-arkitekturer kan endast hämta och lagra värden i arbetsminnet genom särskilda minnesinstruktioner (ofta kalladeload ochstore).
Hoppinstruktioner tillåter programmet att ändrainstruktionssekvensens normalt linjära förlopp genom att ändra värdet påinstruktionspekaren.Greninstruktioner tillåter dessutom hopp som betingas av ett villkor (till exempel "utför hoppet endast om ett registervärde är lika med noll). Förgreningar/hopp kan bland annat ske vidIf-satser,loopar,goto-satser ochfunktionsanrop. Hoppinstruktioner är avgörande för programmering; utan dem går det inte att skrivaprogramslingor.
Anropsinstruktioner möjliggörabstraktion genom att tillåta anrop tillsubrutiner. Processorn lagrar en returadress (nästa instruktion) och börjar exekvera subrutinens instruktioner. När enreturinstruktion påträffas återställs den lagrade returadressen, varpå processorn fortsätter exekvera sekventiellt. Särskildasystemanropsinstruktioner anroparoperativsystemet å programmets vägnar för att utföra operativsystemspecifika funktioner som till exempel att läsa fråndatafiler eller visa text påbildskärmen.
Några av processorns instruktioner är endast avsedda att användas av operativsystemet; dessasysteminstruktioner är "skyddade" i det avseendet att om ett användarprogram försöker använda dem så avbryts programmet omedelbart av operativsystemet. Några processorarkitekturer (somIntel 8080 ochx86) har speciella in- och utenhetsinstruktioner som används för att kommunicera med kringutrustning; dessa är skyddade i moderna operativsystem för att förhindra att flera program orsakar konflikter genom att försöka använda sig av samma kringenhet samtidigt.
Beroende på processorns arkitektur kan en typisk instruktion specificera 0 eller flera explicitaadresser till de operander (argument) eller andraparametrar som används i operationen; här medräknas även adressen till den plats där resultatet lagras (i förekommande fall). Instruktionsuppsättningar kan kategoriseras alltefter hur många adresser instruktionerna använder som mest.
Operander kan vara av olika typer:
mov eax,[31340000h]
(x86-instruktion)mov eax,[esi+12h]