forked from OSchip/llvm-project
[asan, myriad] Use local pool for new/delete when ASan run-time is not up
This can happen on Myriad RTEMS so needs to be handled. Differential Revision: https://reviews.llvm.org/D47916 llvm-svn: 334329
This commit is contained in:
parent
e53fa05763
commit
5a780ee9a9
|
@ -24,6 +24,7 @@
|
||||||
#include "asan_allocator.h"
|
#include "asan_allocator.h"
|
||||||
#include "asan_interceptors.h"
|
#include "asan_interceptors.h"
|
||||||
#include "asan_internal.h"
|
#include "asan_internal.h"
|
||||||
|
#include "asan_malloc_local.h"
|
||||||
#include "asan_stack.h"
|
#include "asan_stack.h"
|
||||||
|
|
||||||
// ---------------------- Replacement functions ---------------- {{{1
|
// ---------------------- Replacement functions ---------------- {{{1
|
||||||
|
@ -67,12 +68,19 @@ static int PosixMemalignFromLocalPool(void **memptr, uptr alignment,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// On RTEMS, we use the local pool to handle memory allocation before
|
#if SANITIZER_RTEMS
|
||||||
// the ASan run-time has been initialized.
|
void* MemalignFromLocalPool(uptr alignment, uptr size) {
|
||||||
static INLINE bool EarlyMalloc() {
|
void *ptr = nullptr;
|
||||||
return SANITIZER_RTEMS && (!asan_inited || asan_init_is_running);
|
alignment = Max(alignment, kWordSize);
|
||||||
|
PosixMemalignFromLocalPool(&ptr, alignment, size);
|
||||||
|
return ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool IsFromLocalPool(const void *ptr) {
|
||||||
|
return IsInDlsymAllocPool(ptr);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
static INLINE bool MaybeInDlsym() {
|
static INLINE bool MaybeInDlsym() {
|
||||||
// Fuchsia doesn't use dlsym-based interceptors.
|
// Fuchsia doesn't use dlsym-based interceptors.
|
||||||
return !SANITIZER_FUCHSIA && asan_init_is_running;
|
return !SANITIZER_FUCHSIA && asan_init_is_running;
|
||||||
|
|
|
@ -0,0 +1,44 @@
|
||||||
|
//===-- asan_malloc_local.h -------------------------------------*- C++ -*-===//
|
||||||
|
//
|
||||||
|
// The LLVM Compiler Infrastructure
|
||||||
|
//
|
||||||
|
// This file is distributed under the University of Illinois Open Source
|
||||||
|
// License. See LICENSE.TXT for details.
|
||||||
|
//
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
//
|
||||||
|
// This file is a part of AddressSanitizer, an address sanity checker.
|
||||||
|
//
|
||||||
|
// Provide interfaces to check for and handle local pool memory allocation.
|
||||||
|
//===----------------------------------------------------------------------===//
|
||||||
|
|
||||||
|
#ifndef ASAN_MALLOC_LOCAL_H
|
||||||
|
#define ASAN_MALLOC_LOCAL_H
|
||||||
|
|
||||||
|
#include "sanitizer_common/sanitizer_platform.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() {
|
||||||
|
return SANITIZER_RTEMS && (!__asan::asan_inited ||
|
||||||
|
__asan::asan_init_is_running);
|
||||||
|
}
|
||||||
|
|
||||||
|
void* MemalignFromLocalPool(uptr alignment, uptr size);
|
||||||
|
|
||||||
|
#if SANITIZER_RTEMS
|
||||||
|
|
||||||
|
bool IsFromLocalPool(const void *ptr);
|
||||||
|
|
||||||
|
#define ALLOCATE_FROM_LOCAL_POOL UNLIKELY(EarlyMalloc())
|
||||||
|
#define IS_FROM_LOCAL_POOL(ptr) UNLIKELY(IsFromLocalPool(ptr))
|
||||||
|
|
||||||
|
#else // SANITIZER_RTEMS
|
||||||
|
|
||||||
|
#define ALLOCATE_FROM_LOCAL_POOL 0
|
||||||
|
#define IS_FROM_LOCAL_POOL(ptr) 0
|
||||||
|
|
||||||
|
#endif // SANITIZER_RTEMS
|
||||||
|
|
||||||
|
#endif // ASAN_MALLOC_LOCAL_H
|
|
@ -14,6 +14,7 @@
|
||||||
|
|
||||||
#include "asan_allocator.h"
|
#include "asan_allocator.h"
|
||||||
#include "asan_internal.h"
|
#include "asan_internal.h"
|
||||||
|
#include "asan_malloc_local.h"
|
||||||
#include "asan_report.h"
|
#include "asan_report.h"
|
||||||
#include "asan_stack.h"
|
#include "asan_stack.h"
|
||||||
|
|
||||||
|
@ -69,12 +70,24 @@ enum class align_val_t: size_t {};
|
||||||
} // namespace std
|
} // namespace std
|
||||||
|
|
||||||
// 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
|
||||||
|
// allocator behavior.
|
||||||
#define OPERATOR_NEW_BODY(type, nothrow) \
|
#define OPERATOR_NEW_BODY(type, nothrow) \
|
||||||
|
if (ALLOCATE_FROM_LOCAL_POOL) {\
|
||||||
|
void *res = MemalignFromLocalPool(SHADOW_GRANULARITY, size);\
|
||||||
|
if (!nothrow) CHECK(res);\
|
||||||
|
return res;\
|
||||||
|
}\
|
||||||
GET_STACK_TRACE_MALLOC;\
|
GET_STACK_TRACE_MALLOC;\
|
||||||
void *res = asan_memalign(0, size, &stack, type);\
|
void *res = asan_memalign(0, size, &stack, type);\
|
||||||
if (!nothrow && UNLIKELY(!res)) ReportOutOfMemory(size, &stack);\
|
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) {\
|
||||||
|
void *res = MemalignFromLocalPool((uptr)align, size);\
|
||||||
|
if (!nothrow) CHECK(res);\
|
||||||
|
return res;\
|
||||||
|
}\
|
||||||
GET_STACK_TRACE_MALLOC;\
|
GET_STACK_TRACE_MALLOC;\
|
||||||
void *res = asan_memalign((uptr)align, size, &stack, type);\
|
void *res = asan_memalign((uptr)align, size, &stack, type);\
|
||||||
if (!nothrow && UNLIKELY(!res)) ReportOutOfMemory(size, &stack);\
|
if (!nothrow && UNLIKELY(!res)) ReportOutOfMemory(size, &stack);\
|
||||||
|
@ -129,18 +142,22 @@ INTERCEPTOR(void *, _ZnamRKSt9nothrow_t, size_t size, std::nothrow_t const&) {
|
||||||
#endif // !SANITIZER_MAC
|
#endif // !SANITIZER_MAC
|
||||||
|
|
||||||
#define OPERATOR_DELETE_BODY(type) \
|
#define OPERATOR_DELETE_BODY(type) \
|
||||||
|
if (IS_FROM_LOCAL_POOL(ptr)) return;\
|
||||||
GET_STACK_TRACE_FREE;\
|
GET_STACK_TRACE_FREE;\
|
||||||
asan_delete(ptr, 0, 0, &stack, type);
|
asan_delete(ptr, 0, 0, &stack, type);
|
||||||
|
|
||||||
#define OPERATOR_DELETE_BODY_SIZE(type) \
|
#define OPERATOR_DELETE_BODY_SIZE(type) \
|
||||||
|
if (IS_FROM_LOCAL_POOL(ptr)) return;\
|
||||||
GET_STACK_TRACE_FREE;\
|
GET_STACK_TRACE_FREE;\
|
||||||
asan_delete(ptr, size, 0, &stack, type);
|
asan_delete(ptr, size, 0, &stack, type);
|
||||||
|
|
||||||
#define OPERATOR_DELETE_BODY_ALIGN(type) \
|
#define OPERATOR_DELETE_BODY_ALIGN(type) \
|
||||||
|
if (IS_FROM_LOCAL_POOL(ptr)) return;\
|
||||||
GET_STACK_TRACE_FREE;\
|
GET_STACK_TRACE_FREE;\
|
||||||
asan_delete(ptr, 0, static_cast<uptr>(align), &stack, type);
|
asan_delete(ptr, 0, static_cast<uptr>(align), &stack, type);
|
||||||
|
|
||||||
#define OPERATOR_DELETE_BODY_SIZE_ALIGN(type) \
|
#define OPERATOR_DELETE_BODY_SIZE_ALIGN(type) \
|
||||||
|
if (IS_FROM_LOCAL_POOL(ptr)) return;\
|
||||||
GET_STACK_TRACE_FREE;\
|
GET_STACK_TRACE_FREE;\
|
||||||
asan_delete(ptr, size, static_cast<uptr>(align), &stack, type);
|
asan_delete(ptr, size, static_cast<uptr>(align), &stack, type);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue