ECOOP 2015
Sun 5 - Fri 10 July 2015 Prague, Czech Republic
Thu 9 Jul 2015 16:30 - 17:00 at Bohemia - Parallelism Chair(s): Walter Binder

Correctness of concurrent objects is defined in terms of conditions that determine allowable relationships between histories of a concurrent object and those of the corresponding sequential object. Numerous correctness conditions have been proposed over the years, and more have been proposed recently as the algorithms implementing concurrent objects have been adapted to cope with multicore processors with relaxed memory architectures.

We present a formal framework for defining correctness conditions for multicore architectures, covering both standard conditions for totally ordered memory and newer conditions for relaxed memory, which allows them to be expressed in uniform manner, simplifying comparison. Our framework distinguishes between order and commitment properties, which in turn enables a hierarchy of correctness conditions to be established. We consider the Total Store Order (TSO) memory model in detail, formalise known conditions for TSO using our framework, and develop sequentially consistent variations of these. We present a work-stealing deque for TSO memory that is not linearizable, but is correct with respect to these new conditions. Using our framework, we identify a new non-blocking compositional condition, fence consistency, which lies between known conditions for TSO, and aims to capture the intention of a programmer-specified fence.

Thu 9 Jul

15:30 - 17:00: Research Track - Parallelism at Bohemia
Chair(s): Walter BinderUniversity of Lugano
research-track143644860000015:30 - 16:00
Shams ImamRice University, Vivek SarkarRice University
research-track143645040000016:00 - 16:30
Gustavo PetriPurdue University, Jan VitekNortheastern University, Suresh JagannathanDARPA
research-track143645220000016:30 - 17:00
Brijesh DongolBrunel University, John DerrickUniversity of Sheffield, Lindsay GrovesVictoria University of Wellington, Graeme SmithThe University of Queensland