Hva er en instruksjonsrørledning?

Hva er en instruksjonsrørledning?

Enhver prosessorinstruksjon har flere trinn i driften. Hvert av disse stadiene tar en enkelt CPU-syklus å fullføre. Disse stadiene er Instruksjonshenting, Instruksjonsdekoding, Utfør, Minnetilgang og Tilbakeskrivning. Disse får henholdsvis instruksjonen som skal fullføres, skiller operasjonen fra verdiene som opereres på, utfører prosessen, åpner registeret som resultatet skal skrives på og skriver resultatet til det åpnede registeret.

Historiske prosessorer i rekkefølge

I tidlige datamaskiner brukte ikke CPU en instruksjonsrørledning. I disse CPUene måtte hver enkeltsyklusoperasjon skje for hver instruksjon. Dette betydde at det tok fem klokkesykluser før den gjennomsnittlige instruksjonen ble behandlet helt før den neste kunne startes. Noen operasjoner trenger kanskje ikke å skrive noe resultat ut til et register, noe som betyr at minnetilgangs- og tilbakeskrivningsstadiene kan hoppes over.

Hva er en instruksjonsrørledning?

I en subskalær prosessor uten pipeline, blir hver del av hver instruksjon utført i rekkefølge.

Det er imidlertid et problem som lurer når du kjører en fullstendig instruksjon i rekkefølge før du kan gå videre til neste instruksjon. Problemet er cache-missen. CPU-en lagrer data den aktivt behandler i registeret. Dette kan nås med en en-syklus latency. Problemet er at registeret er lite fordi det er innebygd i prosessorkjernen. CPU-en må gå til den større, men tregere L1-cachen hvis dataene ikke allerede er lastet inn. Hvis den ikke er der, må den gå til den større og tregere L2-cachen igjen. Det neste trinnet er L3-cachen; det siste alternativet er system-RAM. Hvert av disse alternativene tar flere og flere CPU-sykluser å sjekke.

Nå kan denne ekstra ekstra ventetiden være et stort problem i et system som må fullføre hver instruksjon i sin helhet før du starter neste instruksjon. Det som hadde vært en 5-syklus per instruksjonsprosessor, kan plutselig bli hengt opp i én instruksjon for dusinvis eller hundrevis av klokkesykluser. Hele tiden kan ingenting annet skje på datamaskinen. Teknisk sett kan dette lindres noe ved å ha to uavhengige kjerner. Ingenting hindrer dem begge i å gjøre det samme, potensielt samtidig. Så å gå nedover flerkjerneruten løser ikke dette.

Den klassiske RISC-rørledningen

RISC står for Reduced Instruction Set Computer . Det er en prosessordesignstil som optimerer ytelsen ved å gjøre dekodingen av hver instruksjon enklere. Dette er i forhold til CISC eller Complex Instruction Set Computer, som designer mer komplekse instruksjonssett som gjør at færre instruksjoner er nødvendige for å utføre de samme oppgavene.

Den klassiske RISC-designen inkluderer en instruksjonsrørledning. I stedet for å kjøre noen av de fem instruksjonstrinnene i en gitt syklus, lar rørledningen alle fem trinnene utføres. Selvfølgelig kan du ikke kjøre alle fem trinnene i en instruksjon i en syklus. Men du kan stille fem påfølgende instruksjoner i kø med en forskyvning på ett trinn hver. På denne måten kan en ny instruksjon fullføres hver klokkesyklus. Tilbyr en potensiell 5x ytelsesøkning for en relativt lav økning i kjernekompleksitet.

Hva er en instruksjonsrørledning?

I en skalær pipelinet prosessor kan hvert trinn i en instruksjonsutførelse utføres én gang per klokkesyklus. Dette tillater en maksimal gjennomstrømning på én fullført instruksjon per syklus.

Prosessorer som ikke har en pipeline kan bare være sub-skalære, siden de ikke kan utføre en komplett instruksjon per syklus. Med denne primære fem-trinns pipeline kan du lage en skalar CPU som kan fullføre en instruksjon for hver prosess. Ved å lage enda mer vidtrekkende rørledninger kan du lage superskalære CPUer som kan utføre mer enn én instruksjon per klokkesyklus. Selvfølgelig er det fortsatt potensielle problemer.

Fortsatt sekvensiell

Ingenting av dette løser problemet med å vente i mange sykluser på svar når det er behov for å spørre etter de forskjellige nivåene av cache og RAM. Det introduserer også et nytt problem. Hva om en instruksjon er avhengig av utdata fra den forrige instruksjonen? Disse problemene løses uavhengig med en avansert dispatcher. Den planlegger utførelsesrekkefølgen nøye slik at ingen instruksjoner som er avhengige av utdata fra en annen er for nær hverandre. Den håndterer også cache-misser ved å parkere en instruksjon og erstatte den i rørledningen med andre instruksjoner som er klare til å kjøre og som ikke krever resultatet, og fortsetter instruksjonen når den er klar.

Disse løsningene kan fungere på prosessorer uten pipeline, men de kreves for en superskalarprosessor som kjører mer enn én instruksjon per klokke. En grenprediktor er også svært nyttig ettersom den kan prøve å forutsi utfallet av en instruksjon med mer enn ett potensielt utfall og fortsette å anta at det er riktig med mindre annet er bevist.

Konklusjon

En pipeline gjør at alle prosessorens distinkte muligheter kan brukes i hver syklus. Den gjør dette ved å kjøre forskjellige stadier av forskjellige instruksjoner samtidig. Dette legger ikke engang mye kompleksitet til CPU-designet. Det baner også vei for å tillate mer enn én instruksjon å utføre et enkelt trinn per syklus.


Hvordan klone en harddisk

Hvordan klone en harddisk

I den moderne digitale tidsalder, hvor data er en verdifull ressurs, kan kloning av en harddisk på Windows være en avgjørende prosess for mange. Denne omfattende guiden

Hvordan fikse driveren WUDFRd kunne ikke lastes inn på Windows 10?

Hvordan fikse driveren WUDFRd kunne ikke lastes inn på Windows 10?

Står du overfor feilmeldingen mens du starter datamaskinen som sier at driveren WUDFRd ikke kunne lastes inn på datamaskinen?

Slik fikser du NVIDIA GeForce Experience-feilkode 0x0003

Slik fikser du NVIDIA GeForce Experience-feilkode 0x0003

Opplever du NVIDIA GeForce-opplevelsesfeilkode 0x0003 på skrivebordet ditt? Hvis ja, les bloggen for å finne ut hvordan du løser denne feilen raskt og enkelt.

Hva er SMPS?

Hva er SMPS?

Lær hva som er SMPS og betydningen av ulike effektivitetsvurderinger før du velger en SMPS for datamaskinen din.

Hvorfor slås ikke Chromebooken på

Hvorfor slås ikke Chromebooken på

Få svar på spørsmålet Hvorfor slås ikke Chromebooken min på? I denne nyttige veiledningen for Chromebook-brukere.

Slik rapporterer du phishing-svindel til Google

Slik rapporterer du phishing-svindel til Google

Lær hvordan du rapporterer en svindler til Google for å forhindre at de svindler andre med denne veiledningen.

Roomba stopper, stikker og snur – fiks

Roomba stopper, stikker og snur – fiks

Løs et problem der Roomba-robotstøvsugeren stopper, fester seg og fortsetter å snu.

Hvordan endre grafikkinnstillinger på Steam Deck

Hvordan endre grafikkinnstillinger på Steam Deck

Steam Deck tilbyr en robust og allsidig spillopplevelse rett ved fingertuppene. Men for å optimere spillingen din og sikre best mulig

Hva er isolasjonsbasert sikkerhet?

Hva er isolasjonsbasert sikkerhet?

Skulle fordype seg i et emne som blir stadig viktigere i verden av cybersikkerhet: isolasjonsbasert sikkerhet. Denne tilnærmingen til

Slik bruker du Auto Clicker for Chromebook

Slik bruker du Auto Clicker for Chromebook

I dag skulle du fordype deg i et verktøy som kan automatisere repeterende klikkeoppgaver på Chromebooken din: Auto Clicker. Dette verktøyet kan spare deg for tid og