Zoo: A Framework for the Verification of Concurrent OCaml 5 Programs using Separation Logic

Research output: Contribution to journalArticlepeer-review

Abstract

The release of Ocaml 5, which introduced parallelism in the OCaml runtime, drove the need for safe and efficient concurrent data structures. New libraries like Saturn address this need. This is an opportunity to apply and further state-of-the-art program verification techniques. We present Zoo, a framework for verifying fine-grained concurrent OCaml 5 algorithms. Following a pragmatic approach, we defined a limited but sufficient fragment of the language to faithfully express these algorithms: ZooLang. We formalized its semantics carefully via a deep embedding in the Rocq proof assistant, uncovering subtle aspects of physical equality. We provide a tool to translate source OCaml programs into ZooLang syntax embedded inside Rocq, where they can be specified and verified using the Iris concurrent separation logic. To illustrate the applicability of Zoo, we verified a subset of the standard library and a collection of fined-grained concurrent data structures from the Saturn and Eio libraries. In the process, we also extended OCaml to more efficiently express certain concurrent programs.

Original languageEnglish
Pages (from-to)1702-1729
Number of pages28
JournalProceedings of the ACM on Programming Languages
Volume10
DOIs
Publication statusPublished - 8 Jan 2026

Keywords

  • Concurrent Algorithms
  • Iris
  • OCaml 5
  • Rocq
  • Separation Logic
  • Verification

Fingerprint

Dive into the research topics of 'Zoo: A Framework for the Verification of Concurrent OCaml 5 Programs using Separation Logic'. Together they form a unique fingerprint.

Cite this