Score: 1

Soteria: Efficient Symbolic Execution as a Functional Library

Published: November 11, 2025 | arXiv ID: 2511.08729v4

By: Sacha-Élie Ayoun, Opale Sjöstedt, Azalea Raad

Potential Business Impact:

Finds bugs in computer code faster and better.

Business Areas:
Semantic Search Internet Services

Symbolic execution (SE) tools often rely on intermediate languages (ILs) to support multiple programming languages, promising reusability and efficiency. In practice, this approach introduces trade-offs between performance, accuracy, and language feature support. We argue that building SE engines \emph{directly} for each source language is both simpler and more effective. We present Soteria, a lightweight OCaml library for writing SE engines in a functional style, without compromising on performance, accuracy or feature support. Soteria enables developers to construct SE engines that operate directly over source-language semantics, offering \emph{configurability}, compositional reasoning, and ease of implementation. Using Soteria, we develop Soteria$^{\text{Rust}}$, the \emph{first} Rust SE engine supporting Tree Borrows (the intricate aliasing model of Rust), and Soteria$^{\text{C}}$, a compositional SE engine for C. Both tools are competitive with or outperform state-of-the-art tools such as Kani, Pulse, CBMC and Gillian-C in performance and the number of bugs detected. We formalise the theoretical foundations of Soteria and prove its soundness, demonstrating that sound, efficient, accurate, and expressive SE can be achieved without the compromises of ILs.

Country of Origin
🇬🇧 United Kingdom

Page Count
37 pages

Category
Computer Science:
Programming Languages