Parosh Aziz Abdulla ; Mohamed Faouzi Atig ; Stefanos Kaxiras ; Carl Leonardsson ; Alberto Ros et al. - Mending Fences with Self-Invalidation and Self-Downgrade

lmcs:2542 - Logical Methods in Computer Science, January 16, 2018, Volume 14, Issue 1 - https://doi.org/10.23638/LMCS-14(1:6)2018
Mending Fences with Self-Invalidation and Self-DowngradeArticle

Authors: Parosh Aziz Abdulla ; Mohamed Faouzi Atig ; Stefanos Kaxiras ; Carl Leonardsson ; Alberto Ros ORCID; Yunyun Zhu

    Cache coherence protocols based on self-invalidation and self-downgrade have recently seen increased popularity due to their simplicity, potential performance efficiency, and low energy consumption. However, such protocols result in memory instruction reordering, thus causing extra program behaviors that are often not intended by the programmers. We propose a novel formal model that captures the semantics of programs running under such protocols, and features a set of fences that interact with the coherence layer. Using the model, we design an algorithm to analyze the reachability and check whether a program satisfies a given safety property with the current set of fences. We describe a method for insertion of optimal sets of fences that ensure correctness of the program under such protocols. The method relies on a counter-example guided fence insertion procedure. One feature of our method is that it can handle a variety of fences (with different costs). This diversity makes optimization more difficult since one has to optimize the total cost of the inserted fences, rather than just their number. To demonstrate the strength of our approach, we have implemented a prototype and run it on a wide range of examples and benchmarks. We have also, using simulation, evaluated the performance of the resulting fenced programs.


    Volume: Volume 14, Issue 1
    Published on: January 16, 2018
    Accepted on: October 26, 2017
    Submitted on: November 23, 2016
    Keywords: Computer Science - Logic in Computer Science,D.2.4,F.3.1

    Consultation statistics

    This page has been seen 2162 times.
    This article's PDF has been downloaded 433 times.