Verifying safety of a token coherence implementation by parametric compositional refinement

3Citations
Citations of this article
6Readers
Mendeley users who have this article in their library.
Get full text

Abstract

We combine compositional reasoning and reachability analysis to formally verify the safety of a recent cache coherence protocol. The protocol is a detailed implementation of token coherence, an approach that decouples correctness and performance. First, we present a formal and abstract specification that captures the safety substrate of token coherence, and highlights the symmetry in states of the cache controllers and contents of the messages they exchange. Then, we prove that this abstract specification is coherent, and check whether the implementation proposed by the protocol designers is a refinement of the abstract specification. Our refinement proof is parametric in the number of cache controllers, and is compositional as it reduces the refinement checks to individual controllers using a specialized form of assume-guarantee reasoning. The individual refinement obligations are discharged using refinement maps and reachability analysis. While the formal proof justifies the intuitive claim by the designers about the ease of verifiability of token coherence, we report on several bugs in the implementation, and accompanying modifications, that were missed by extensive prior simulations. © Springer-Verlag Berlin Heidelberg 2005.

Cite

CITATION STYLE

APA

Burckhardt, S., Alur, R., & Martin, M. M. K. (2005). Verifying safety of a token coherence implementation by parametric compositional refinement. In Lecture Notes in Computer Science (Vol. 3385, pp. 130–145). Springer Verlag. https://doi.org/10.1007/978-3-540-30579-8_9

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free