Interactive proofs in higher-order concurrent separation logic


Robbert Krebbers, Amin Timany, and Lars Birkedal: Interactive proofs in higher-order concurrent separation logic. In Proceedings of the 44th ACM SIGPLAN Symposium on Principles of Programming Languages, POPL 2017, January 2017. https://doi.org/10.1145/3009837.3009855
Conference Paper
Keywords: Separation Logic, Interactive Theorem Proving, Coq, Fine-grained Concurrency, Logical Relations
Abstract.

When using a proof assistant to reason in an embedded logic — like separation logic — one cannot benefit from the proof contexts and basic tactics of the proof assistant. This results in proofs that are at a too low level of abstraction because they are cluttered with bookkeeping code related to manipulating the object logic.

In this paper, we introduce a so-called proof mode that extends the Coq proof assistant with (spatial and non-spatial) named proof contexts for the object logic. We show that thanks to these contexts we can implement high-level tactics for introduction and elimination of the connectives of the object logic, and thereby make reasoning in the embedded logic as seamless as reasoning in the meta logic of the proof assistant. We apply our method to Iris: a state of the art higher-order impredicative concurrent separation logic.

We show that our method is very general, and is not just limited to program verification. We demonstrate its generality by formalizing correctness proofs of fine-grained concurrent algorithms, derived constructs of the Iris logic, and a unary and binary logical relation for a language with concurrency, higher-order store, polymorphism, and recursive types. This is the first formalization of a binary logical relation for such an expressive language. We also show how to use the logical relation to prove contextual refinement of fine-grained concurrent algorithms.

The bibtex source for this publication:
@inproceedings{DBLP:conf/popl/KrebbersTB17,
  author    = {Robbert Krebbers and
               Amin Timany and
               Lars Birkedal},
  title     = {Interactive proofs in higher-order concurrent separation logic},
  booktitle = {Proceedings of the 44th {ACM} {SIGPLAN} Symposium on Principles of
               Programming Languages, {POPL} 2017, Paris, France, January 18-20,
               2017},
  pages     = {205--217},
  year      = {2017},
  url       = {http://dl.acm.org/citation.cfm?id=3009855},
  timestamp = {Wed, 28 Dec 2016 13:22:29 +0100},
  biburl    = {http://dblp.org/rec/bib/conf/popl/KrebbersTB17},
  bibsource = {dblp computer science bibliography, http://dblp.org}
 }