Nesting-safe recoverable linearizability: Modular constructions for non-volatile memory

    Research output: Chapter in Book/Report/Conference proceedingConference contributionpeer-review

    37 Scopus citations

    Abstract

    We presents a novel abstract individual-process crash-recovery model for non-volatile memory, which enables modularity, so that complex recoverable objects can be constructed in a modular manner from simpler recoverable base objects. Within the framework of this model, we define nesting-safe recoverable linearizability (NRL) - a novel correctness condition that captures the requirements for nesting recoverable objects. Informally, NRL allows the recovery code to extend the interval of the failed operation until the recovery code succeeds to complete (possibly after multiple failures and recovery attempts). Unlike previous correctness definitions, the NRL condition implies that, following recovery, an implemented (higher-level) recoverable operation is able to complete its invocation of a base-object operation and obtain its response. We present algorithms for nesting-safe recoverable primitives, namely, recoverable versions of widely-used primitive shared-memory operations such as read, write, test-and-set and compare- and-swap, which can be used to implement higher-level recoverable objects. We then exemplify how these recoverable base objects can be used for constructing a recoverable counter object. Finally, we prove an impossibility result on wait-free implementations of recoverable test-and-set (TAS) objects from read, write and TAS operations, thus demonstrating that our model also facilitates rigorous analysis of the limitations of recoverable concurrent objects.

    Original languageEnglish
    Title of host publicationPODC 2018 - Proceedings of the 2018 ACM Symposium on Principles of Distributed Computing
    PublisherAssociation for Computing Machinery
    Pages7-16
    Number of pages10
    ISBN (Print)9781450357951
    DOIs
    StatePublished - 23 Jul 2018
    Event37th ACM SIGACT-SIGOPS Symposium on Principles of Distributed Computing, PODC 2018 - Egham, United Kingdom
    Duration: 23 Jul 201827 Jul 2018

    Publication series

    NameProceedings of the Annual ACM Symposium on Principles of Distributed Computing

    Conference

    Conference37th ACM SIGACT-SIGOPS Symposium on Principles of Distributed Computing, PODC 2018
    Country/TerritoryUnited Kingdom
    CityEgham
    Period23/07/1827/07/18

    Keywords

    • Concurrency
    • Lock-freedom
    • Multi-core algorithms
    • Nonblocking
    • Shared memory
    • Wait-freedom

    ASJC Scopus subject areas

    • Software
    • Hardware and Architecture
    • Computer Networks and Communications

    Fingerprint

    Dive into the research topics of 'Nesting-safe recoverable linearizability: Modular constructions for non-volatile memory'. Together they form a unique fingerprint.

    Cite this