The term stack safety is used for a variety of compiler, run-time, and hardware mechanisms for protecting stack memory. Unlike "the heap," the ISA-level stack does not correspond to a single high-level language concept: different compilers use it in different ways to support procedural and functional abstraction mechanisms from a wide range of languages. This protean nature makes it difficult to nail down what it means to correctly enforce stack safety. We propose a formal characterization of stack safety using concepts from language-based security. Rather than packaging all aspects of stack safety into a monolithic property, we decompose it into an integrity property and a confidentiality property for each of the caller and the callee, plus a control-flow property -- five properties in all. This formulation is motivated by a particular class of enforcement mechanisms, the ``lazy'' stack safety micro-policies studied by Roessler and DeHon~\cite{DBLP:conf/sp/RoesslerD18}, which permit functions to write into one another's frames, but which taint the changed locations so that the frame's owner cannot access it. No existing characterization of stack safety captures this style of safety. We capture it here by stating our properties in terms of the observable behavior of the system. Our properties go further than previous formal definitions of stack safety, supporting caller- and callee-saved registers, arguments passed on the stack, and tail-call elimination. We validate our properties by using them to distinguish between correct and incorrect implementations of Roessler and DeHon's micro-policies using property-based random testing. Our test harness successfully identifies several broken variants, including Roessler and DeHon's lazy policy; a repaired version of their policy does pass our tests.
翻译:堆叠安全一词用于各种编译器、运行时间和硬件机制来保护堆叠内存。 与“ 堆积” 不同, ISA 级堆叠与单个高层次语言概念不匹配: 不同的编译者以不同的方式使用它来支持程序和功能性抽象机制, 包括多种语言。 这种蛋白性质使得很难精确地描述正确执行堆叠安全的含义。 我们建议使用基于语言的安保概念来正式描述堆叠安全。 我们不将堆叠安全的所有方面包装成一个单流属性, 我们把它分解成一个完整性属性和保密属性, 每一个调用人和调用人, 加上控制流属性 -- 五个属性。 这种配制是由某种特定的执行机制驱动的, 由Roessler 和 DeHon ⁇ cite 所研究的“ 堆叠安全微观政策” ( DBLLP: conf/ sp/ / Roessler D18}, 它允许将堆叠安全功能写入另一个框架, 但是它会将改变的位置和保密性标之间的保密性属性, 因此, 框架的调用我们的游戏主的游戏定义无法正确性定义获取。 没有对我们的安全性测试, 我们的系统进行现有的安全性能进行。