Passer à la navigation principale Passer à la recherche Passer au contenu principal

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

Résultats de recherche: Contribution à un journalArticleRevue par des pairs

Résumé

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.

langue originaleAnglais
Pages (de - à)1702-1729
Nombre de pages28
journalProceedings of the ACM on Programming Languages
Volume10
Les DOIs
étatPublié - 8 janv. 2026

Empreinte digitale

Examiner les sujets de recherche de « Zoo: A Framework for the Verification of Concurrent OCaml 5 Programs using Separation Logic ». Ensemble, ils forment une empreinte digitale unique.

Contient cette citation