Iris-MSWasm: Elucidating and Mechanising the Security Invariants of Memory-Safe WebAssembly


연구 분야: Verification



학회: Proceedings of the ACM on Programming Languages, Volume 8, Issue OOPSLA2


초록

WebAssembly offers coarse-grained encapsulation guarantees via its module system, but does not support fine-grained sharing of its linear memory. MSWasm is a recent proposal which extends WebAssembly with fine-grained memory sharing via handles, a type of capability that guarantees spatial and temporal safety, and thus enables an expressive yet safe style of programming with flexible sharing. In this paper, we formally validate the pen-and-paper design of MSWasm. To do so, we first define MSWasmCert, a mechanisation of MSWasm that makes it a fully-defined, conservative extension of WebAssembly 1.0, including the module system. We then develop Iris-MSWasm, a foundational reasoning framework for MSWasm composed of a separation logic to reason about known code, and a logical relation to reason about unknown, potentially adversarial code. Iris-MSWasm thereby makes explicit a key aspect of the implicit universal contract of MSWasm: robust capability safety. We apply Iris-MSWasm to reason about key use cases of handles, in which the effect of calling an unknown function is bounded by robust capability safety. Iris-MSWasm thus works as a framework to prove complex security properties of MSWasm programs, and provides a foundation to evaluate the language-level guarantees of MSWasm.


Author Profile
Aïna Linn Georges

MPI-SWS Saarbrücken Germany

Germany
Author Profile
Maxime Legoupil

Aarhus University Aarhus Denmark

Denmark
Author Profile
June Rousseau

Aarhus University Aarhus Denmark

Denmark

📄 논문 정보

발행 연도 2024년
인용수 1
출판 국가 Germany, Denmark
사이트 ACM
좋아요 수 0

연관 논문 목록 (5건)