Sandcrust
Autor: | Carsten Weinhold, Adam Lackorzynski, Hermann Härtig, Benjamin Lamowski |
---|---|
Rok vydání: | 2017 |
Předmět: |
010302 applied physics
Computer science Programming language 020207 software engineering Memory corruption 02 engineering and technology computer.software_genre 01 natural sciences Domain (software engineering) Memory management 0103 physical sciences 0202 electrical engineering electronic engineering information engineering Compiler Memory model Macro computer Memory safety Rust (programming language) computer.programming_language |
Zdroj: | PLOS@SOSP |
DOI: | 10.1145/3144555.3144562 |
Popis: | System-level development has been dominated by traditional programming languages such as C and C++ for decades. These languages are inherently unsafe regarding memory management. Even experienced developers make mistakes that open up security holes or compromise the safety properties of software. The Rust programming language is targeted at the systems domain and aims to eliminate memory-related programming errors by enforcing a strict memory model at the language and compiler level. Unfortunately, these compile-time guarantees no longer hold when a Rust program is linked against a library written in unsafe C, which is commonly required for functionality where an implementation in Rust is not yet available.In this paper, we present Sandcrust, an easy-to-use sand-boxing solution for isolating code and data of a C library in a separate process. This isolation protects the Rust-based main program from any memory corruption caused by bugs in the unsafe library, which would otherwise invalidate the memory safety guarantees of Rust. Sandcrust is based on the Rust macro system and requires no modification to the compiler or runtime, but only straightforward annotation of functions that call the library's API. |
Databáze: | OpenAIRE |
Externí odkaz: |