Specifying and Verifying Concurrent Algorithms with Histories and Subjectivity

  • Ilya Sergey
  • Aleksandar Nanevski
  • Anindya Banerjee
Conference paper

DOI: 10.1007/978-3-662-46669-8_14

Part of the Lecture Notes in Computer Science book series (LNCS, volume 9032)
Cite this paper as:
Sergey I., Nanevski A., Banerjee A. (2015) Specifying and Verifying Concurrent Algorithms with Histories and Subjectivity. In: Vitek J. (eds) Programming Languages and Systems. ESOP 2015. Lecture Notes in Computer Science, vol 9032. Springer, Berlin, Heidelberg

Abstract

We present a lightweight approach to Hoare-style specifications for fine-grained concurrency, based on a notion of time-stamped histories that abstractly capture atomic changes in the program state. Our key observation is that histories form a partial commutative monoid, a structure fundamental for representation of concurrent resources. This insight provides us with a unifying mechanism that allows us to treat histories just like heaps in separation logic. For example, both are subject to the same assertion logic and inference rules (e.g., the frame rule). Moreover, the notion of ownership transfer, which usually applies to heaps, has an equivalent in histories. It can be used to formally represent helping—an important design pattern for concurrent algorithms whereby one thread can execute code on behalf of another. Specifications in terms of histories naturally abstract away the internal interference, so that sophisticated fine-grained algorithms can be given the same specifications as their simplified coarse-grained counterparts, making them equally convenient for client-side reasoning. We illustrate our approach on a number of examples and validate all of them in Coq.

Preview

Unable to display preview. Download preview PDF.

Unable to display preview. Download preview PDF.

Copyright information

© Springer-Verlag Berlin Heidelberg 2015

Authors and Affiliations

  • Ilya Sergey
    • 1
  • Aleksandar Nanevski
    • 1
  • Anindya Banerjee
    • 1
  1. 1.IMDEA Software InstituteMadridSpain

Personalised recommendations