The High-Level Benefits of Low-Level Sandboxing

被引:10
|
作者
Sammler, Michael [1 ,2 ]
Garg, Deepak [1 ]
Dreyer, Derek [1 ]
Litak, Tadeusz [2 ]
机构
[1] MPI SWS, Saarland Informat Campus, Saarbrucken, Germany
[2] Friedrich Alexander Univ Erlangen Nurnberg, Erlangen, Germany
基金
欧洲研究理事会;
关键词
Sandboxing; robust safety; Iris; type systems; logical relations; language-based security; CHECKING;
D O I
10.1145/3371100
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Sandboxing is a common technique that allows low-level, untrusted components to safely interact with trusted code. However, previous work has only investigated the low-level memory isolation guarantees of sandboxing, leaving open the question of the end-to-end guarantees that sandboxing affords programmers. In this paper, we fill this gap by showing that sandboxing enables reasoning about the known concept of robust safety, i.e., safety of the trusted code even in the presence of arbitrary untrusted code. To do this, we first present an idealized operational semantics for a language that combines trusted code with untrusted code. Sandboxing is built into our semantics. Then, we prove that safety properties of the trusted code (as enforced through a rich type system) are upheld in the presence of arbitrary untrusted code, so long as all interactions with untrusted code occur at the "any" type (a type inhabited by all values). Finally, to alleviate the burden of having to interact with untrusted code at only the "any" type, we formalize and prove safe several wrappers, which automatically convert values between the "any" type and much richer types. All our results are mechanized in the Coq proof assistant.
引用
收藏
页数:32
相关论文
共 50 条