no.phhsnews.com


no.phhsnews.com / Når er en CPU-cache spylt tilbake til hovedminne?

Når er en CPU-cache spylt tilbake til hovedminne?


Hvis du nettopp begynner å lære hvordan flere kjerne-CPUer, caching, cache-sammenheng og minne fungerer, kan det virke litt litt forvirrende først. Med det i betraktning har dagens SuperUser Q & A-post svar på et nysgjerrig lesers spørsmål.

Dagens Spørsmål og svar-sesjon kommer til oss med høflighet av SuperUser-en underavdeling av Stack Exchange, en fellesskapsdrevet gruppe av Q & A-nettsteder.

Spørsmålet

SuperUser-leser CarmeloS vil vite når en CPU-cache blir spylt tilbake til hovedminne:

Hvis jeg har en CPU med to kjerner, og hver kjerne har sin egen L1-buffer, er det mulig at Core1 og Core2 både cache samme del av minnet på samme tid? Hvis det er mulig, hva vil verdien av hovedminne være hvis både Core1 og Core2 har redigert sine verdier i cachen?

Når er en CPU-cache spylt tilbake til hovedminnet?

Svaret

SuperUser-bidragsytere David Schwartz, Sleske og Kimberly W har svaret for oss. Først opp, David Schwartz:

Hvis jeg har en CPU med to kjerner, og hver kjerne har sin egen L1-buffer, er det mulig at Core1 og Core2 begge cache samme del av minnet samtidig?

Ja, ytelse ville være forferdelig hvis dette ikke var tilfelle. Tenk på to tråder som kjører samme kode. Du vil ha den koden i begge L1-cachene.

Hvis det er mulig, hva vil verdien av hovedminne være hvis både Core1 og Core2 har redigert sine verdier i cachen?

Den gamle verdien vil være i hovedminnet, hvilket spiller ingen rolle siden ingen av kjerne vil lese den. Før du sender ut en endret verdi fra hurtigbufferen, må den skrives til minnet. Vanligvis brukes noen variant av MESI-protokollen. I den tradisjonelle implementeringen av MESI, hvis en verdi er endret i en cache, kan den ikke være til stede i en hvilken som helst annen hurtigbuffer på samme nivå.

Etterfulgt av svaret fra sleske:

Ja, å ha to caches cache Det samme minnesområdet kan skje og er faktisk et problem som skjer mye i praksis. Det finnes forskjellige løsninger, for eksempel:

  • De to cachene kan kommunisere for å sikre at de ikke er uenige.
  • Du kan ha en slags veileder som overvåker alle caches og oppdaterer dem tilsvarende.
  • Hver prosessor overvåker minnesområdene at den har cachet, og når den oppdager en skrive, kaster den ut sin (nå ugyldige) cache

Problemet kalles cache-sammenheng, og Wikipedia-artikkelen om emnet har en fin oversikt over problemet og mulige løsninger.

Og vårt endelige svar fra Kimberly W:

For å svare på spørsmålet i tittelens innlegg, avhenger det av hva cacheprotokollen er. Hvis det er tilbakekalling, blir cachen bare skyllet tilbake til hovedminnet når hurtigbufferen ikke har annet valg enn å sette en ny hurtigbuffer i allerede opptatt plass. Blokken som tidligere okkuperte rommet er fjernet, og verdien er skrevet tilbake til hovedminnet.

Den andre protokollen er gjennomskrivning. I dette tilfellet, når cacheblokken er skrevet på nivå n , oppdateres den tilsvarende blokk på nivå n + 1 . Det er likt i konsept å fylle ut et skjema med karbonpapir under; hva du skriver på toppen, kopieres på arket under. Dette er tregere fordi det åpenbart innebærer flere skriveoperasjoner, men verdiene mellom caches er mer konsistente. I tilbakestillingsprogrammet vil bare cache på høyeste nivå ha den mest oppdaterte verdien for en bestemt minneblokk.


Har du noe å legge til forklaringen? Lyder av i kommentarene. Vil du lese flere svar fra andre tech-savvy Stack Exchange-brukere? Se full diskusjonstråd her.

Bilde Kreditt: Lemsipmatt (Flickr)


Slik kjører du Windows-programvare på en Chromebook

Slik kjører du Windows-programvare på en Chromebook

Chromebooks kjører vanligvis ikke Windows-programvare - det er det beste og verste med dem. Du trenger ikke antivirus eller annet Windows-søppel ... men du kan heller ikke installere Photoshop, den fullstendige versjonen av Microsoft Office eller andre Windows-skrivebordsprogrammer. Heldigvis finnes det måter å bruke Windows-skrivebordsprogrammer på en Chromebook: enten kjører dem eksternt på et eksisterende Windows-system, gjennom ulike Android-løsninger, eller får hendene skitne i utviklingsmodus og kjører dem på Chromebook-enheten selv.

(how-top)

Slik bruker du en fysisk fjernkontroll med Chromecast-enheten din

Slik bruker du en fysisk fjernkontroll med Chromecast-enheten din

Googles Chromecast gjør det enkelt å bla etter videoer og se dem på TVen din, men hva hvis du vil pause avspillingen raskt uten å nå for din smarttelefon eller datamaskin? Du kan nå gjøre dette direkte fra TVens innebygde fjernkontroll. Denne funksjonen benytter en funksjon som kalles HDMI-CEC. Gjennom HDMI-CEC-standarden tilbyr de fleste moderne TV-apparater, du kan nå bruke den fysiske fjernkontrollen som fulgte med TVen, for å pause og pause videoer mens de spiller på Chromecast.

(how-top)