//===- ASanStackFrameLayout.h - ComputeASanStackFrameLayout -----*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This header defines ComputeASanStackFrameLayout and auxiliary data structs. // //===----------------------------------------------------------------------===// #ifndef LLVM_TRANSFORMS_UTILS_ASANSTACKFRAMELAYOUT_H #define LLVM_TRANSFORMS_UTILS_ASANSTACKFRAMELAYOUT_H #include "llvm/ADT/SmallString.h" #include "llvm/ADT/SmallVector.h" namespace llvm { class AllocaInst; // These magic constants should be the same as in // in asan_internal.h from ASan runtime in compiler-rt. static const int kAsanStackLeftRedzoneMagic = …; static const int kAsanStackMidRedzoneMagic = …; static const int kAsanStackRightRedzoneMagic = …; static const int kAsanStackUseAfterReturnMagic = …; static const int kAsanStackUseAfterScopeMagic = …; // Input/output data struct for ComputeASanStackFrameLayout. struct ASanStackVariableDescription { … }; // Output data struct for ComputeASanStackFrameLayout. struct ASanStackFrameLayout { … }; ASanStackFrameLayout ComputeASanStackFrameLayout( // The array of stack variables. The elements may get reordered and changed. SmallVectorImpl<ASanStackVariableDescription> &Vars, // AddressSanitizer's shadow granularity. Usually 8, may also be 16, 32, 64. uint64_t Granularity, // The minimal size of the left-most redzone (header). // At least 4 pointer sizes, power of 2, and >= Granularity. // The resulting FrameSize should be multiple of MinHeaderSize. uint64_t MinHeaderSize); // Compute frame description, see DescribeAddressIfStack in ASan runtime. SmallString<64> ComputeASanStackFrameDescription( const SmallVectorImpl<ASanStackVariableDescription> &Vars); // Returns shadow bytes with marked red zones. This shadow represents the state // if the stack frame when all local variables are inside of the own scope. SmallVector<uint8_t, 64> GetShadowBytes(const SmallVectorImpl<ASanStackVariableDescription> &Vars, const ASanStackFrameLayout &Layout); // Returns shadow bytes with marked red zones and after scope. This shadow // represents the state if the stack frame when all local variables are outside // of the own scope. SmallVector<uint8_t, 64> GetShadowBytesAfterScope( // The array of stack variables. The elements may get reordered and changed. const SmallVectorImpl<ASanStackVariableDescription> &Vars, const ASanStackFrameLayout &Layout); } // llvm namespace #endif // LLVM_TRANSFORMS_UTILS_ASANSTACKFRAMELAYOUT_H