Issue No.11 - November (2001 vol.50)
DOI Bookmark: http://doi.ieeecomputersociety.org/10.1109/12.966493
<p><b>Abstract</b>—Value locality, a recently discovered program attribute that describes the likelihood of the recurrence of previously seen program values, has been studied enthusiastically in the recent published literature. Much of the energy has focused on refining the initial efforts at predicting load instruction outcomes, with the balance of the effort examining the value locality of either all register-writing instructions or a focused subset of them. Surprisingly, there has been very little published characterization of or effort to exploit the value locality of data words stored to memory by computer programs. This paper presents such a characterization, including detailed source-level analysis of the causes of silent stores, proposes both memory-centric (based on message passing) and producer-centric (based on program structure) prediction mechanisms for stored data values, introduces the concept of silent stores and new definitions of multiprocessor false sharing based on these observations, and suggests new techniques for aligning cache coherence protocols and microarchitectural store handling techniques to exploit the value locality of stores. We find that realistic implementations of these techniques can significantly reduce multiprocessor data bus traffic and are more effective at reducing address bus traffic than the addition of Exclusive state to a MSI coherence protocol. We also show that squashing of silent stores can provide uniprocessor speedups greater than the addition of store-to-load forwarding.</p>
Value locality, value prediction, store optimization, false sharing, cache coherence.
Kevin M. Lepak, Mikko H. Lipasti, "Silent Stores and Store Value Locality", IEEE Transactions on Computers, vol.50, no. 11, pp. 1174-1190, November 2001, doi:10.1109/12.966493