forked from OSchip/llvm-project
[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:
parent
ee4e0a2942
commit
9e0edce564
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue