Shadow Stack

A shadow stack is a mechanism for protecting a procedure's stored return address, such as from a stack buffer overflow. The shadow stack itself is a second, separate stack that "shadows" the program call stack. In the function prologue, a function stores its return address to both the call stack and the shadow stack. In the function epilogue, a function loads the return address from both the call stack and the shadow stack, and then compares them. If the two records of the return address differ, then an attack is detected.

ID: d3f:ShadowStack
Type:

Informational References

https://d3fend.mitre.org/dao/artifact/d3f:ShadowStack/

D3FEND Techniques

Name Description

SPARTA Countermeasures

ID Name Description