Pokud se právě začínáte naučit, jak pracují vícejádrové procesory, ukládání do mezipaměti, koherence mezipaměti a paměti, nejprve matoucí. S ohledem na to má dnešní příspěvek SuperUser Q & A odpovědi na zvědavou čtenářskou otázku.
Dnešní dotazy týkající se otázky Otázka a odpověď se k nám přicházejí s laskavým svolením SuperUser - subdivize Stack Exchange, komunitní skupiny webových stránek Q & A. > Otázka
Pokud mám CPU se dvěma jádry a každé jádro má vlastní L1 cache, je možné, že Core1 a Core2 současně ukládat do paměti stejnou část paměti? Pokud je to možné, jaká bude hodnota hlavní paměti, pokud Core1 a Core2 upraví své hodnoty v mezipaměti?
Kdy je mezipaměť CPU proplavena zpět do hlavní paměti?
Odpovědi
Pokud mám CPU se dvěma jádry a každé jádro má vlastní L1 cache, je možné, že Core1 a Core2 současně ukládají do paměti stejnou část paměti?
Ano, výkon by byl hrozný, kdyby tomu tak nebylo. Zvažte dva podprocesy se stejným kódem. Chcete kód v obou mezipaměti L1
Pokud je to možné, jaká bude hodnota hlavní paměti v případě, že Core1 a Core2 upraví své hodnoty v mezipaměti?
Stará hodnota bude v hlavní paměti, nezáleží na tom, jelikož jádro ji nebude číst. Před vysunutím upravené hodnoty z mezipaměti musí být zapsána do paměti. Obvykle se používá některá varianta protokolu MESI. V tradiční implementaci MESI, pokud je hodnota změněna v jedné mezipaměti, nemůže být vůbec přítomna v žádné jiné mezipaměti na stejné úrovni.
Následuje odpověď sleske:
Ano, má dvě mezipaměti mezipaměti může dojít ke stejné paměťové oblasti a je to vlastně problém, který se v praxi vyskytuje hodně. Existují různá řešení, například:
Dvě vyrovnávací paměti mohou komunikovat, aby se ujistily, že nesouhlasí
- Můžete mít nějakého supervizora, který sleduje všechny mezipaměti a odpovídajícím způsobem je aktualizuje
- Každý procesor sleduje paměťové oblasti že má mezipaměť a když detekuje zápis, vyhazuje svou (nyní neplatnou) mezipaměť
- Problém se nazývá koherence mezipaměti a článek Wikipedie o tématu má pěkný přehled problému a možných řešení.
A naše konečná odpověď od Kimberly W:
Chcete-li odpovědět na otázku v názvu vašeho příspěvku, záleží na tom, co je protokol ukládání do mezipaměti. Pokud se jedná o zpětný zápis, mezipaměť bude vrácena zpět do hlavní paměti pouze tehdy, když má správce mezipaměti jinou možnost než vložení nového mezipaměti do již obsazeného prostoru. Blok, který dříve obsadil prostor, je odebrán a jeho hodnota je zapsána zpět do hlavní paměti.
Druhý protokol je zápis. V takovém případě kdykoli je mezipaměť zapsána na úrovni
n , aktualizuje se odpovídající blok na úrovni n + 1 . V konceptu je podobná vyplňování formuláře s podtlakovým papírem; vše, co píšete nahoře, je zkopírováno na list níže. To je pomalejší, protože samozřejmě zahrnuje více operací psaní, ale hodnoty mezi mezipaměti jsou konzistentnější. V schématu zápisu zpětné vazby by měla nejaktuálnější mezní hodnota pro určitý paměťový blok pouze mezipaměť nejvyšší úrovně. Musíte něco přidat k vysvětlení? Zní to v komentářích. Chcete se dozvědět více odpovědí od ostatních uživatelů technologie Stack Exchange? Podívejte se na celý diskusní příspěvek zde.
Image Credit: Lemsipmatt (Flickr)
Jak se obrátit malinový písek do boxu BitTorrent vždy
Je ideální mít specializovaný stroj pro váš BitTorrent klient, takže se můžete osvěžit 24/7. Je však energeticky náročné nechat plnou plošinu zapnutou a on-line, že často. Návod pro měření spotřeby energie Většina stolních počítačů získává značné množství energie - náš skromný server domácí kanceláře například spotřebuje téměř 200 dolarů elektřiny za rok.
Jak přepracovat tlačítka ovládacího prvku Xbox One v systému Windows 10
Systém Windows 10 nyní umožňuje přepočítat tlačítka ovládacího prvku Xbox One stejně jako můžete přepočítat tlačítka na konzole Xbox One. Tato funkce je součástí aplikace Xbox Příslušenství, která není ve výchozím nastavení nainstalována. Omezení Tato nová funkce přemapování zcela bohužel zcela nevylučuje potřebu aplikací pro remapování řadičů třetích stran.