[asan] Fix debug asan build link error

Reviewers: dmajor, vitalybuka, waltl

Subscribers: kubamracek, #sanitizers, llvm-commits

Tags: #sanitizers, #llvm

Differential Revision: https://reviews.llvm.org/D61871

llvm-svn: 361427
This commit is contained in:
Reid Kleckner 2019-05-22 20:29:12 +00:00
parent ee4e0a2942
commit 9e0edce564
2 changed files with 29 additions and 26 deletions

View File

@ -17,25 +17,34 @@
#include "sanitizer_common/sanitizer_platform.h" #include "sanitizer_common/sanitizer_platform.h"
#include "asan_internal.h" #include "asan_internal.h"
// On RTEMS, we use the local pool to handle memory allocation when the ASan
// run-time is not up.
static INLINE bool EarlyMalloc() { static INLINE bool EarlyMalloc() {
return SANITIZER_RTEMS && (!__asan::asan_inited || return SANITIZER_RTEMS &&
__asan::asan_init_is_running); (!__asan::asan_inited || __asan::asan_init_is_running);
} }
void* MemalignFromLocalPool(uptr alignment, uptr size);
#if SANITIZER_RTEMS #if SANITIZER_RTEMS
bool IsFromLocalPool(const void *ptr); bool IsFromLocalPool(const void *ptr);
void *MemalignFromLocalPool(uptr alignment, uptr size);
// On RTEMS, we use the local pool to handle memory allocation when the ASan
// run-time is not up. This macro is expanded in the context of the operator new
// implementation.
#define MAYBE_ALLOCATE_FROM_LOCAL_POOL(nothrow) \
do { \
if (UNLIKELY(EarlyMalloc())) { \
void *res = MemalignFromLocalPool(SHADOW_GRANULARITY, size); \
if (!nothrow) \
CHECK(res); \
return res; \
} \
} while (0)
#define ALLOCATE_FROM_LOCAL_POOL UNLIKELY(EarlyMalloc())
#define IS_FROM_LOCAL_POOL(ptr) UNLIKELY(IsFromLocalPool(ptr)) #define IS_FROM_LOCAL_POOL(ptr) UNLIKELY(IsFromLocalPool(ptr))
#else // SANITIZER_RTEMS #else // SANITIZER_RTEMS
#define ALLOCATE_FROM_LOCAL_POOL 0 #define MAYBE_ALLOCATE_FROM_LOCAL_POOL(nothrow)
#define IS_FROM_LOCAL_POOL(ptr) 0 #define IS_FROM_LOCAL_POOL(ptr) 0
#endif // SANITIZER_RTEMS #endif // SANITIZER_RTEMS

View File

@ -71,25 +71,19 @@ enum class align_val_t: size_t {};
// TODO(alekseyshl): throw std::bad_alloc instead of dying on OOM. // TODO(alekseyshl): throw std::bad_alloc instead of dying on OOM.
// For local pool allocation, align to SHADOW_GRANULARITY to match asan // For local pool allocation, align to SHADOW_GRANULARITY to match asan
// allocator behavior. // allocator behavior.
#define OPERATOR_NEW_BODY(type, nothrow) \ #define OPERATOR_NEW_BODY(type, nothrow) \
if (ALLOCATE_FROM_LOCAL_POOL) {\ MAYBE_ALLOCATE_FROM_LOCAL_POOL(nothrow); \
void *res = MemalignFromLocalPool(SHADOW_GRANULARITY, size);\ GET_STACK_TRACE_MALLOC; \
if (!nothrow) CHECK(res);\ void *res = asan_memalign(0, size, &stack, type); \
return res;\ if (!nothrow && UNLIKELY(!res)) \
}\ ReportOutOfMemory(size, &stack); \
GET_STACK_TRACE_MALLOC;\
void *res = asan_memalign(0, size, &stack, type);\
if (!nothrow && UNLIKELY(!res)) ReportOutOfMemory(size, &stack);\
return res; return res;
#define OPERATOR_NEW_BODY_ALIGN(type, nothrow) \ #define OPERATOR_NEW_BODY_ALIGN(type, nothrow) \
if (ALLOCATE_FROM_LOCAL_POOL) {\ MAYBE_ALLOCATE_FROM_LOCAL_POOL(nothrow); \
void *res = MemalignFromLocalPool((uptr)align, size);\ GET_STACK_TRACE_MALLOC; \
if (!nothrow) CHECK(res);\ void *res = asan_memalign((uptr)align, size, &stack, type); \
return res;\ if (!nothrow && UNLIKELY(!res)) \
}\ ReportOutOfMemory(size, &stack); \
GET_STACK_TRACE_MALLOC;\
void *res = asan_memalign((uptr)align, size, &stack, type);\
if (!nothrow && UNLIKELY(!res)) ReportOutOfMemory(size, &stack);\
return res; return res;
// On OS X it's not enough to just provide our own 'operator new' and // On OS X it's not enough to just provide our own 'operator new' and