Higher-Order Separation Logic in Isabelle/HOLCF

Carsten Varming, Lars Birkedal

    Research output: Journal Article or Conference Article in JournalConference articleResearchpeer-review

    Abstract

    We formalize higher-order separation logic for a first-order imperative language with procedures and local variables in Isabelle/HOLCF. The assertion language is modeled in such a way that one may use any theory defined in Isabelle/HOLCF to construct assertions, e.g., primitive recursion, least or greatest fixed points etc. The higher-order logic ensures that we can show non-trivial algorithms correct without having to extend the semantics of the language as was done previously in verifications based on first-order separation logic [2,20]. We provide non-trivial examples to support this claim and to show how the higher-order logic enables natural assertions in specifications. To support abstract reasoning we have implemented rules for representation hiding and data abstraction as seen in [1].
    The logic is represented as lemmas for reasoning about the denotational semantics of the programming language. This follows the definitional approach common in HOL theorem provers, i.e., the soundness of our model only relies on the soundness of Isabelle/HOL [6]. We use our formalization to give a formally verified proof of Cheney's copying garbage collector [4] using a tagged representation of objects. The proof generalizes the results in [2]. The proof uses an encoding of the separation logic formula this(h) to capture the heap from before the garbage collection and thus shows
    another novel use of higher-order separation logic.
    Original languageEnglish
    JournalElectronical Notes in Theoretical Computer Science
    Pages (from-to)371-389
    Number of pages18
    ISSN1571-0661
    DOIs
    Publication statusPublished - 2008
    EventMathematical Foundations of Programming Semantics - University of Pennsylvania, United States
    Duration: 22 May 200825 May 2008
    Conference number: 24

    Conference

    ConferenceMathematical Foundations of Programming Semantics
    Number24
    Country/TerritoryUnited States
    CityUniversity of Pennsylvania
    Period22/05/200825/05/2008

    Keywords

    • Higher-Order Separation Logic
    • First-Order Imperative Language
    • Denotational Semantics
    • Isabelle/HOLCF
    • Cheney's Copying Garbage Collector

    Cite this