Zápis do vyrovnávací paměti - Write buffer

A vyrovnávací paměť pro zápis je typ vyrovnávací paměť dat používá se jistě Mezipaměť CPU architektury jako Intel x86 a AMD64.[1] Ve vícejádrových systémech se vyrovnávací paměti zápisu ničí sekvenční konzistence. Některé softwarové disciplíny, jako C11 svoboda rasy dat,[2] jsou dostatečné k opětovnému získání konzistentního pohledu na paměť.

V mezipaměti CPU lze k zápisu použít vyrovnávací paměť pro zápis data se zapisuje z mezipaměti do hlavní paměť nebo do další mezipaměti v hierarchie paměti. Toto je variace přepis volání do mezipaměti vyrovnávací paměť pro zápis.

Použití vyrovnávací paměti pro zápis tímto způsobem uvolní mezipaměť na požadavky na čtení služby, zatímco probíhá zápis. To je zvláště užitečné pro velmi pomalou hlavní paměť, protože následná čtení mohou pokračovat bez čekání na dlouhou latenci hlavní paměti. Když je zapisovací paměť plná (tj. Všechny položky vyrovnávací paměti jsou obsazené), musí další zápisy ještě počkat, až se sloty uvolní. Následná čtení lze provádět z vyrovnávací paměti pro zápis. K dalšímu zmírnění tohoto stání může být implementována jedna optimalizace zvaná sloučení vyrovnávací paměti zápisu. Sloučení vyrovnávací paměti pro zápis kombinuje zápisy které mají po sobě jdoucí cílové adresy do jedné položky vyrovnávací paměti. V opačném případě by obsadili samostatné vstupy, což zvyšuje pravděpodobnost zablokování potrubí.

A nárazník oběti je typ vyrovnávací paměti pro zápis, ve které jsou uloženy špinavé vypuzené řádky odepsat mezipaměti[poznámka 1] aby se zapsali zpět do hlavní paměti. Kromě omezení zablokování potrubí tím, že nebudete čekat, až špinavé řádky budou odepisovat zpět, jak to dělá jednoduchá vyrovnávací paměť pro zápis, může vyrovnávací paměť oběti také sloužit jako dočasné zálohovací úložiště, když se projeví následné přístupy do mezipaměti lokalita požadující ty nedávno vystěhované linky, které jsou stále v bufferu oběti.

Poznámky

  1. ^ Zápis cache nepotřebují zapisovat řádky vystěhované mezipaměti, protože se při zápisu do mezipaměti zapisují do hlavní paměti.


  1. ^ Owens, Scott, Susmit Sarkar a Peter Sewell. „Lepší model paměti x86: x86-TSO.“ Věta prokazující logiku vyšších řádů. Springer Berlin Heidelberg, 2009. 391-407.
  2. ^ Oberhauser, Jonas. „Věta o jednodušší redukci pro x86-TSO.“ Ověřený software: Teorie, nástroje a experimenty. Springer International Publishing, 2015. 142-164