Precise Reasoning About Container-Internal Pointers with Logical Pinning
Yawen Guan, Clément Pit-Claudel
TL;DR
The paper tackles the challenge of reasoning about container-internal pointers that containers expose temporarily, which many separation-logic frameworks struggle to support. It introduces logical pinning, a lightweight borrowing model with pointer-stability classifications and tagged multi-hole contexts, enabling precise, modular specifications that track which subparts are pinned or borrowed. A step-by-step proof discipline—identifying borrowable subparts, enriching APIs, and proving correctness with explicit borrow/return steps—underpins the approach, supported by borrowable data types and predicate transformers that compose ${}^{\flat}$ and ${}^{\ast}$. Case studies from flat containers to recursive structures demonstrate that logical pinning subsumes existing proof patterns, simplifies complex proofs, and enables reasoning about expose-then-mutate patterns, with all results mechanized in the Rocq proof assistant using CFML.
Abstract
Most separation logics hide container-internal pointers for modularity. This makes it difficult to specify container APIs that temporarily expose those pointers to the outside, and to verify programs that use these APIs. We present logical pinning, a lightweight borrowing model for sequential programs that allows users to selectively track container-internal pointers at the logical level. Our model generalizes the magic-wand operator for representing partial data structures, making it easy to write and prove precise specifications, including pointer-stability properties. Because it only changes the way representation predicates and specifications are written, our approach is compatible with most separation logic variants. We demonstrate the practicality of logical pinning by verifying small but representative pointer-manipulating programs, and deriving more precise versions of common container specifications. In doing so, we show that our approach subsumes some well-known proof patterns, simplifies some complex proofs, and enables reasoning about program patterns not supported by traditional specifications. All of our results are mechanized in the Rocq proof assistant, using the CFML library.
