Předběžné načítání mezipaměti - Cache prefetching
Předběžné načítání mezipaměti je technika používaná počítačovými procesory ke zvýšení výkonu provádění načítáním instrukcí nebo dat z jejich původního úložiště v pomalejší paměti do rychlejší lokální paměti, než je skutečně potřeba (odtud termín „prefetch“).[1] Většina moderních počítačových procesorů má rychlé a místní mezipaměť ve kterém jsou předem načtená data uložena, dokud nejsou požadována. Zdrojem operace předběžného načtení je obvykle hlavní paměť. Kvůli jejich designu, přístupu mezipaměti paměti je obvykle mnohem rychlejší než přístup hlavní paměť, takže předběžné načítání dat a následný přístup z mezipaměti je obvykle o mnoho řádů rychlejší než přímý přístup k nim hlavní paměť. Předběžné načítání lze provést neblokováním pokyny pro ovládání mezipaměti.
Předběžné načítání mezipaměti dat vs. instrukcí
Předběžné načítání mezipaměti může do mezipaměti načíst data nebo pokyny.
- Předběžné načítání dat načte data dříve, než je potřeba. Protože vzory přístupu k datům vykazují méně pravidelnosti než vzory instrukcí, přesné předběžné načítání dat je obecně náročnější než předběžné načítání instrukcí.
- Předběžné načítání pokynů načte pokyny dříve, než je třeba je provést. První běžné mikroprocesory, které používaly nějakou formu předběžného načítání instrukcí, byly Intel 8086 (šest bajtů) a Motorola 68000 (čtyři bajty). V posledních letech používají všechny vysoce výkonné procesory techniky předběžného načítání.
Předběžné načítání mezipaměti hardware vs. software
Předběžného načítání mezipaměti lze dosáhnout buď hardwarem, nebo softwarem.[2]
- Předběžné načítání založené na hardwaru je obvykle dosaženo tím, že má v procesoru vyhrazený hardwarový mechanismus, který sleduje proud instrukcí nebo dat požadovaných prováděcím programem, rozpoznává několik dalších prvků, které program může na základě tohoto proudu potřebovat, a přednačte do mezipaměti procesoru.[3]
- Softwarové předběžné načítání je obvykle dosaženo tím, že kompilátor analyzuje kód a vloží další "prefetch" instrukce do programu během samotné kompilace.[4]
Metody předběžného načítání hardwaru
Vyrovnávací paměti streamů
- Vyrovnávací paměti streamů byly vyvinuty na základě konceptu „schématu jednoho bloku LookLead (OBL)“ navrženého Alan Jay Smith.[1]
- Proud Nárazníky jsou jednou z nejběžnějších používaných technologií předběžného načítání založených na hardwaru.[5] Tuto techniku původně navrhl Norman Jouppi v roce 1990[6] a od té doby bylo vyvinuto mnoho variací této metody.[7][8][9] Základní myšlenkou je, že miss miss adresa (a následující adresy) jsou načteny do samostatné vyrovnávací paměti hloubky . Tato vyrovnávací paměť se nazývá vyrovnávací paměť streamu a je oddělená od mezipaměti. Procesor poté spotřebovává data / instrukce z vyrovnávací paměti streamu, pokud se adresa spojená s předem načtenými bloky shoduje s požadovanou adresou generovanou programem prováděným na procesoru. Obrázek níže ilustruje toto nastavení:
- Kdykoli mechanismus předběžného načtení zjistí zmeškaný paměťový blok, řekněme A, přidělí datový proud k zahájení předběžného načítání po sobě jdoucích bloků od zmeškaného bloku kupředu. Pokud vyrovnávací paměť streamu pojme 4 bloky, pak bychom předem načetli A + 1, A + 2, A + 3, A + 4 a zadrželi je v přidělené vyrovnávací paměti streamu. Pokud procesor spotřebuje další A + 1, bude přesunut „nahoru“ z vyrovnávací paměti streamu do mezipaměti procesoru. První položka vyrovnávací paměti streamu by nyní byla A + 2 atd. Tento vzor předběžného načítání po sobě jdoucích bloků se nazývá Postupné předběžné načítání. Používá se hlavně tehdy, když mají být předem načtena souvislá místa. Například se používá při předběžném načítání pokynů.
- Tento mechanismus lze zvětšit přidáním více takových „vyrovnávacích pamětí streamu“ - z nichž by každý udržoval samostatný proud předběžného načtení. Pro každou novou miss by byl přidělen nový stream buffer a fungoval by podobným způsobem, jak je popsáno výše.
- Ideální hloubka vyrovnávací paměti streamu je něco, co je předmětem experimentů s různými měřítky[6] a záleží na zbytku mikroarchitektura zapojen.
Dalším vzorem pokynů pro předběžné načítání je předběžné načítání adres, které jsou adresy dopředu v pořadí. Používá se hlavně v případě, že po sobě jdoucí bloky, které mají být předem načteny, jsou adresy od sebe.[2] Toto se nazývá jako Stridné předběžné načítání.
Metody předběžného načítání softwaru
Předběžné načítání zaměřené na kompilátor
Předběžné načítání zaměřené na kompilátor je široce používáno v rámci smyček s velkým počtem iterací. V této technice kompilátor předpovídá budoucí chyby mezipaměti a vloží instrukci předběžného načtení na základě chybět trest a doba provedení pokynů.
Tyto předběžné načtení neblokují operace paměti, tj. Tyto přístupy do paměti neinterferují se skutečnými přístupy do paměti. Nezmění stav procesoru ani nezpůsobí chyby stránky.
Jednou z hlavních výhod předběžného načítání softwaru je, že snižuje počet povinných chyb v mezipaměti.[2]
Následující příklad ukazuje, jak bude instrukce prefetch přidána do kódu pro vylepšení výkon mezipaměti.
Zvažte smyčku for, jak je znázorněno níže:
pro (int i=0; i<1024; i++) { pole1[i] = 2 * pole1[i];}
Při každé iteraci se ith je přístupný prvek pole „pole1“. Proto můžeme předem načíst prvky, ke kterým se v budoucích iteracích bude přistupovat, vložením instrukce „prefetch“, jak je znázorněno níže:
pro (int i=0; i<1024; i++) { prefetch (pole1 [i + k]); pole1[i] = 2 * pole1[i];}
Tady, prefetch stride, závisí na dvou faktorech, trestu za vynechání mezipaměti a času potřebného k provedení jedné iterace pro smyčka. Například pokud jedna iterace smyčky trvá 7 cyklů a trest za vynechání mezipaměti je 49 cyklů, měli bychom mít - což znamená, že předem načteme 7 prvků. S první iterací bude i 0, takže předem načteme 7. prvek. Nyní s tímto uspořádáním bude prvních 7 přístupů (i = 0-> 6) stále chybět (za zjednodušujícího předpokladu, že každý prvek pole1 je v samostatném samostatném řádku mezipaměti).
Porovnání předběžného načítání hardwaru a softwaru
- Zatímco předběžné načítání softwaru vyžaduje programátor nebo překladač zásah, předběžné načítání hardwaru vyžaduje speciální hardwarové mechanismy.[2]
- Předběžné načítání softwaru funguje dobře pouze se smyčkami, kde je pravidelný přístup k poli, protože programátor musí ručně kódovat pokyny pro předběžné načtení. Zatímco prefetchery hardwaru fungují dynamicky na základě chování programu v runtime.[2]
- Předběžné načítání hardwaru má také menší režii CPU ve srovnání se předběžným načítáním softwaru.[10]
Metriky předběžného načítání mezipaměti
Předběžné načítání mezipaměti posuzuje tři hlavní metriky[2]
Dosah
Pokrytí je zlomek z celkového počtu chyb, které jsou odstraněny z důvodu předběžného načítání, tj.
,
kde,
Přesnost
Přesnost je zlomek celkových přednastavení, která byla užitečná - tj. Poměr počtu přednačtených adres paměti byl programem skutečně odkazován na celkové provedené předvolby.
I když se zdá, že dokonalá přesnost může znamenat, že zde nejsou žádné slevy, není tomu tak. Samotné předběžné načtení může vést k novým chybám, pokud jsou předem načtené bloky umístěny přímo do mezipaměti. I když to může být malý zlomek z celkového počtu zmeškaných, které bychom mohli vidět bez jakéhokoli předběžného načítání, jedná se o nenulový počet zmeškaných.
Včasnost
Kvalitativní definice včasnosti spočívá v tom, jak brzy je blok předběžně načtený oproti tomu, kdy je na něj skutečně odkazováno. Příklad k dalšímu vysvětlení včasnosti je následující:
Zvažte smyčku for, kde každá iterace trvá 3 cykly a operace 'prefetch' trvá 12 cyklů. To znamená, že aby byla prefetched data užitečná, musíme spustit prefetch iterace před jeho použitím, aby byla zachována včasnost.
Viz také
Reference
- ^ A b Smith, Alan Jay (01.09.1982). "Vyrovnávací paměti". ACM Comput. Surv. 14 (3): 473–530. doi:10.1145/356887.356892. ISSN 0360-0300.
- ^ A b C d E F Solihin, Yan (2016). Základy paralelní vícejádrové architektury. Boca Raton, FL: CRC Press, Taylor & Francis Group. str. 163. ISBN 978-1482211184.
- ^ Baer, Jean-Loup; Chen, Tien-Fu (01.01.1991). Efektivní systém předběžného načítání na čipu, který snižuje pokutu za přístup k datům. Konference ACM / IEEE 1991 o superpočítačích. Albuquerque, NM, USA: ACM. 176–186. CiteSeerX 10.1.1.642.703. doi:10.1145/125826.125932. ISBN 978-0897914598.
- ^ Kennedy, Porterfield, Allan (01.01.1989). Softwarové metody pro zlepšení výkonu mezipaměti v aplikacích superpočítačů (Teze). Rice University. hdl:1911/19069.
- ^ Mittal, Sparsh (01.08.2016). „Přehled posledních technik předběžného načítání pro mezipaměti procesorů“. ACM Comput. Surv. 49 (2): 35:1–35:35. doi:10.1145/2907071. ISSN 0360-0300.
- ^ A b C Jouppi, Norman P. (1990). Zlepšení výkonu přímo mapované mezipaměti přidáním malé plně asociativní mezipaměti a vyrovnávacích pamětí prefetch. New York, New York, USA: ACM Press. CiteSeerX 10.1.1.37.6114. doi:10.1145/325164.325162. ISBN 0-89791-366-3.
- ^ Chen, Tien-Fu; Baer, Jean-Loup (01.05.1995). "Efektivní hardwarové předběžné načítání dat pro vysoce výkonné procesory". Transakce IEEE na počítačích. 44 (5): 609–623. doi:10.1109/12.381947. ISSN 0018-9340. S2CID 1450745.
- ^ Palacharla, S .; Kessler, R. E. (01.01.1994). Vyhodnocení vyrovnávacích pamětí streamu jako nahrazení sekundární mezipaměti. 21. výroční mezinárodní symposium o počítačové architektuře. Chicago, IL, USA: IEEE Computer Society Press. str. 24–33. CiteSeerX 10.1.1.92.3031. doi:10.1109 / ISCA.1994.288164. ISBN 978-0818655104.
- ^ Grannaes, Marius; Jahre, Magnus; Natvig, Lasse (2011). "Předběžné načítání hardwaru s efektivním úložištěm pomocí tabulek predikce s korekcí Delta". Journal of Instruction-Level-Parallelism (13): 1–16. CiteSeerX 10.1.1.229.3483.
- ^ Callahan, David; Kennedy, Ken; Porterfield, Allan (01.01.1991). Předběžné načítání softwaru. Čtvrtá mezinárodní konference o architektonické podpoře programovacích jazyků a operačních systémů. Santa Clara, CA, USA: ACM. 40–52. doi:10.1145/106972.106979. ISBN 978-0897913805.