Publication | Open Access
RustHorn: CHC-based Verification for Rust Programs
48
Citations
38
References
2021
Year
Program CheckingEngineeringVerificationSoftware SystemsComputer-aided VerificationSoftware EngineeringSoftware AnalysisFormal VerificationConstrained Horn ClausesDynamic Memory AllocationFormal TechniqueCompilersProgramming LanguagesFormal SpecificationRuntime VerificationRust ProgramsComputer ScienceSoftware VerificationProgram AnalysisAutomated ReasoningFormal MethodsPrototype VerifierSymbolic Execution
Reduction to satisfiability of constrained Horn clauses (CHCs) is a widely studied approach to automated program verification. Current CHC-based methods, however, do not work very well for pointer-manipulating programs, especially those with dynamic memory allocation. This article presents a novel reduction of pointer-manipulating Rust programs into CHCs, which clears away pointers and memory states by leveraging Rust’s guarantees on permission. We formalize our reduction for a simplified core of Rust and prove its soundness and completeness. We have implemented a prototype verifier for a subset of Rust and confirmed the effectiveness of our method.
| Year | Citations | |
|---|---|---|
Page 1
Page 1