Actris: session-type based reasoning in separation logic

Jonas Kastberg Hinrichsen, Jesper Bengtson, Robbert Krebbers

Publikation: Konference artikel i Proceeding eller bog/rapport kapitelKonferencebidrag i proceedingsForskningpeer review

Abstract

Message passing is a useful abstraction to implement concurrent programs. For real-world systems, however,
it is often combined with other programming and concurrency paradigms, such as higher-order functions,
mutable state, shared-memory concurrency, and locks. We present Actris: a logic for proving functional
correctness of programs that use a combination of the aforementioned features. Actris combines the power
of modern concurrent separation logics with a first-class protocol mechanism—based on session types—for
reasoning about message passing in the presence of other concurrency paradigms. We show that Actris
provides a suitable level of abstraction by proving functional correctness of a variety of examples, including a
distributed merge sort, a distributed load-balancing mapper, and a variant of the map-reduce model, using
relatively simple specifications. Soundness of Actris is proved using a model of its protocol mechanism in the
Iris framework. We mechanised the theory of Actris, together with tactics for symbolic execution of programs,
as well as all examples in the paper, in the Coq proof assistant
OriginalsprogEngelsk
TitelProceedings of the ACM on Programming Languages
RedaktørerPhilip Wadler
Antal sider30
Vol/bind4
ForlagAssociation for Computing Machinery
Publikationsdato2020
Sider6:1
Artikelnummer6
DOI
StatusUdgivet - 2020

Emneord

  • message passing
  • concurrent programming
  • separation logics
  • session types
  • functional correctness

Fingeraftryk

Dyk ned i forskningsemnerne om 'Actris: session-type based reasoning in separation logic'. Sammen danner de et unikt fingeraftryk.

Citationsformater