Hva er en minnebarriere?

Historisk sett har CPUer vært perfekt sekvensielle maskiner. Dette er svært logisk og lett å forstå, men kan være et ytelsesproblem. Gjennom årene har det vært mange geniale justeringer av CPU-design for å trekke ut så mye ytelse som mulig fra silisiumskiver. En av de mer interessante er imidlertid utførelse. I prosessorer som ikke er i orden, trenger instruksjoner ikke nødvendigvis å utføres i den rekkefølgen de blir utstedt.

Står i orden

Det viktigste ytelsesproblemet en in-order CPU støter på kalles en pipeline stall. Dette skjer når en instruksjon er avhengig av noe minne, men det minnet ikke er direkte tilgjengelig i et register. I dette tilfellet må CPU finne denne verdien i minnet. CPU-cachen sjekkes først da disse er det raskeste minnenivået. Hvis verdien ikke er der, kontrolleres system-RAM. I løpet av denne tiden må CPU-en sitte inaktiv, da den minneavhengige instruksjonen må fullføres i rekkefølge før følgende instruksjoner.

Ytelsespåvirkningen av en rørledningsstopp er kanskje ikke så ille, men den kan også være relativt alvorlig. For eksempel kan L1-cachen typisk returnere et resultat i størrelsesorden 5 CPU-sykluser. L2-bufferen kan ta 20 sykluser, L3 rundt 200 sykluser, og system-RAM rundt 400 sykluser. Gitt at en CPU kan operere på rundt 5GHz, det vil si 5 milliarder klokkesykluser per sekund, er til og med 400 sykluser ikke så ille (0,000008%). Men hvis du har mange instruksjoner som trenger å referere til data lenger ned i cache-nivåene, kan den kumulative effekten forårsake en merkbar nedgang.

Utelukkende utførelse og navn på register

Utførelse av utførelse er en teknikk som lar planleggeren omorganisere instruksjonene i køen. Gjennom denne omorganiseringen kan den velge å prioritere spesifikke tråder fremfor andre. Den kan også dytte instruksjoner tilbake i køen når de har en dataavhengighet som ennå ikke er oppfylt. Dette forhindrer rørledningsstopp så mye som mulig, og minimerer tomgangssykluser.

Utførelse av utførelse krever en funksjon som kalles navn på register. CPU-en kan få tilgang til data som holdes i registre i løpet av en enkelt syklus. Register brukes til å lagre data som leses og skrives. Det er imidlertid viktig å sikre at datamaskinen ser alt som skjer i den logiske rekkefølgen, ikke i den ut-av-ordne, CPU-syklusoptimaliserte rekkefølgen. For å muliggjøre dette har CPUer mange flere logiske registre enn CPU-arkitekturen krever.

Data som må skrives ut, men som har en «tidligere» instruks som ikke er fullført ennå, legges i et holdingregister. Disse dataene blir ikke overført til et annet register når bestillingen har ordnet seg. I stedet endres navnet på beholdningsregisteret til det på registret det skal stå i. Dette ligner litt på å tilberede en dessert før hovedretten, men så oppbevare den i kjøleskapet til den skal serveres.

Disse logiske registrene er fullstendig uadressert. CPU-en kan bare virkelig adressere de logiske registrene som for øyeblikket deler navnet på de arkitektoniske registrene. Når det er sagt, er CPU-en også klar over dem nok til at hvis andre omorganiserte instruksjoner er avhengige av dataene i det logiske holderegisteret, kan de bruke dem i stedet for de "utdaterte" dataene i arkitekturregisteret på det aktuelle empiriske tidspunktet.

Minnebarrierer

En minnebarriere - også referert til som en membar, minnegjerde eller gjerdeinstruksjon - er en instruksjon i datakode. Det lar en programmerer håndheve en bestillingsbegrensning på minneoperasjoner utstedt før og etter minnebarrieren. Minnebarrieren instruerer CPU-planleggeren om å sikre at alle instruksjoner blir behandlet før instruksjoner etter barrieren. Dette gjøres for å sikre at viktige operasjoner gjennomføres i riktig rekkefølge.

Generelt, på moderne datamaskiner, bør dette ikke være nødvendig. Utførelse av utførelse og navn på register er veletablerte og modne felt. Likevel kan en minnebarriere være nyttig for eldre, mindre sofistikerte prosessorer som ikke er i orden eller brukt i kritiske minneoperasjoner.

Minnebarrierer kan ha en viss ytelsesskade. Dette er fordi de aktivt forhindrer CPU-planleggeren fra å optimalisere spesifikke deler av instruksjonsflyten. Dette øker sjansen for stopp i rørledningen.

Konklusjon

En minnebarriere er en instruksjon som sikrer en bestillingsbegrensning på minneoperasjoner. Dette er viktig fordi prosessorer som ikke er i orden, kan omorganisere spesifikke instruksjoner. Mens omdøping av register er veletablert som en metode for å sikre minneintegritet i dette miljøet, kan det være nyttig å sikre det manuelt.

Minnebarrieren tvinger CPU-planleggeren til å sikre at instruksjoner fullføres før noen instruksjoner etter barrieren. Dette forhindrer at minneoperasjoner blir omorganisert. Det forhindrer også CPU-en i å optimalisere instruksjonsflyten, noe som kan påvirke ytelsen.


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