Verifying Invariants of Lock-Free Data Structures with Rely-Guarantee and Refinement Types

Author:

Gordon Colin S.1ORCID,Ernst Michael D.2,Grossman Dan2,Parkinson Matthew J.3

Affiliation:

1. Drexel University, Philadelphia, USA

2. University of Washington, Seattle, USA

3. Microsoft Research, Cambridge, United Kingdom

Abstract

Verifying invariants of fine-grained concurrent data structures is challenging, because interference from other threads may occur at any time. We propose a new way of proving invariants of fine-grained concurrent data structures: applying rely-guarantee reasoning to references in the concurrent setting. Rely-guarantee applied to references can verify bounds on thread interference without requiring a whole program to be verified. This article provides three new results. First, it provides a new approach to preserving invariants and restricting usage of concurrent data structures. Our approach targets a space between simple type systems and modern concurrent program logics, offering an intermediate point between unverified code and full verification. Furthermore, it avoids sealing concurrent data structure implementations and can interact safely with unverified imperative code. Second, we demonstrate the approach’s broad applicability through a series of case studies, using two implementations: an axiomatic C oq domain-specific language and a library for Liquid Haskell. Third, these two implementations allow us to compare and contrast verifications by interactive proof (C oq ) and a weaker form that can be expressed using automatically-discharged dependent refinement types (Liquid Haskell).

Funder

University of Washington, Samsung Research America, and Drexel University

Publisher

Association for Computing Machinery (ACM)

Subject

Software

Cited by 8 articles. 订阅此论文施引文献 订阅此论文施引文献,注册后可以免费订阅5篇论文的施引文献,订阅后可以查看论文全部施引文献

1. Refinement Types: A Tutorial;Foundations and Trends® in Programming Languages;2021

2. ConSORT: Context- and Flow-Sensitive Ownership Refinement Types for Imperative Programs;Programming Languages and Systems;2020

3. A Continuous Certification Methodology for DevOps;Proceedings of the 11th International Conference on Management of Digital EcoSystems;2019-11-12

4. An evolutionary approach to translating operational specifications into declarative specifications;Science of Computer Programming;2019-07

5. Test-Based Security Certification of Composite Services;ACM Transactions on the Web;2019-02-28

同舟云学术

1.学者识别学者识别

2.学术分析学术分析

3.人才评估人才评估

"同舟云学术"是以全球学者为主线,采集、加工和组织学术论文而形成的新型学术文献查询和分析系统,可以对全球学者进行文献检索和人才价值评估。用户可以通过关注某些学科领域的顶尖人物而持续追踪该领域的学科进展和研究前沿。经过近期的数据扩容,当前同舟云学术共收录了国内外主流学术期刊6万余种,收集的期刊论文及会议论文总量共计约1.5亿篇,并以每天添加12000余篇中外论文的速度递增。我们也可以为用户提供个性化、定制化的学者数据。欢迎来电咨询!咨询电话:010-8811{复制后删除}0370

www.globalauthorid.com

TOP

Copyright © 2019-2024 北京同舟云网络信息技术有限公司
京公网安备11010802033243号  京ICP备18003416号-3