arXiv Open Access 2024

An Operational Semantics for Yul

Vasileios Koutavas Yu-Yang Lin Nikos Tzevelekos
Lihat Sumber

Abstrak

We present a big-step and small-step operational semantics for Yul -- the intermediate language used by the Solidity compiler to produce EVM bytecode -- in a mathematical notation that is congruous with the literature of programming languages, lends itself to language proofs, and can serve as a precise, widely accessible specification for the language. Our two semantics stay faithful to the original, informal specification of the language but also clarify under-specified cases such as void function calls. Our presentation allows us to prove the equivalence between the two semantics. We also implement the small-step semantics in an interpreter for Yul which avails of optimisations that are provably correct. We have tested the interpreter using tests from the Solidity compiler and our own. We envisage that this work will enable the development of verification and symbolic execution technology directly in Yul, contributing to the Ethereum security ecosystem, as well as aid the development of a provably sound future type system.

Topik & Kata Kunci

Penulis (3)

V

Vasileios Koutavas

Y

Yu-Yang Lin

N

Nikos Tzevelekos

Format Sitasi

Koutavas, V., Lin, Y., Tzevelekos, N. (2024). An Operational Semantics for Yul. https://arxiv.org/abs/2407.01365

Akses Cepat

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