arXiv Open Access 2026

Combining Small-Step and Big-Step Semantics to Verify Loop Optimizations

David Knothe Oliver Bringmann
Lihat Sumber

Abstrak

Verified compilers aim to guarantee that compilation preserves the observable behavior of source programs. While small-step semantics are widely used in such compilers, they are not always the most convenient framework for structural transformations such as loop optimizations. This paper proposes an approach that leverages both small-step and big-step semantics: small-step semantics are used for local transformations, while big-step semantics are employed for structural transformations. An abstract behavioral semantics is introduced as a common interface between the two styles. Coinductive big-step semantics is extended to correctly handle divergence with both finite and infinite traces, bringing it on par with the expressiveness of small-step semantics. This enables the insertion of big-step transformations into the middle of an existing small-step pipeline, thereby fully preserving all top-level semantic preservation theorems. This approach is practically demonstrated in CompCert by implementing and verifying a few new loop optimizations in big-step Cminor, including loop unswitching and, notably, full loop unrolling.

Topik & Kata Kunci

Penulis (2)

D

David Knothe

O

Oliver Bringmann

Format Sitasi

Knothe, D., Bringmann, O. (2026). Combining Small-Step and Big-Step Semantics to Verify Loop Optimizations. https://arxiv.org/abs/2602.19868

Akses Cepat

Lihat di Sumber
Informasi Jurnal
Tahun Terbit
2026
Bahasa
en
Sumber Database
arXiv
Akses
Open Access ✓