forked from OSchip/llvm-project
[asan] some renaming before we move StackTrace into sanitizer_common
llvm-svn: 162747
This commit is contained in:
parent
bb6f165952
commit
6b0d775229
|
@ -566,7 +566,7 @@ class MallocInfo {
|
||||||
pg->size_of_chunk = size;
|
pg->size_of_chunk = size;
|
||||||
pg->last_chunk = (uptr)(mem + size * (n_chunks - 1));
|
pg->last_chunk = (uptr)(mem + size * (n_chunks - 1));
|
||||||
int idx = atomic_fetch_add(&n_page_groups_, 1, memory_order_relaxed);
|
int idx = atomic_fetch_add(&n_page_groups_, 1, memory_order_relaxed);
|
||||||
CHECK(idx < (int)ASAN_ARRAY_SIZE(page_groups_));
|
CHECK(idx < (int)ARRAY_SIZE(page_groups_));
|
||||||
page_groups_[idx] = pg;
|
page_groups_[idx] = pg;
|
||||||
return res;
|
return res;
|
||||||
}
|
}
|
||||||
|
@ -593,8 +593,8 @@ void DescribeHeapAddress(uptr addr, uptr access_size) {
|
||||||
CHECK(m->alloc_tid >= 0);
|
CHECK(m->alloc_tid >= 0);
|
||||||
AsanThreadSummary *alloc_thread =
|
AsanThreadSummary *alloc_thread =
|
||||||
asanThreadRegistry().FindByTid(m->alloc_tid);
|
asanThreadRegistry().FindByTid(m->alloc_tid);
|
||||||
AsanStackTrace alloc_stack;
|
StackTrace alloc_stack;
|
||||||
AsanStackTrace::UncompressStack(&alloc_stack, m->compressed_alloc_stack(),
|
StackTrace::UncompressStack(&alloc_stack, m->compressed_alloc_stack(),
|
||||||
m->compressed_alloc_stack_size());
|
m->compressed_alloc_stack_size());
|
||||||
AsanThread *t = asanThreadRegistry().GetCurrent();
|
AsanThread *t = asanThreadRegistry().GetCurrent();
|
||||||
CHECK(t);
|
CHECK(t);
|
||||||
|
@ -602,8 +602,8 @@ void DescribeHeapAddress(uptr addr, uptr access_size) {
|
||||||
AsanThreadSummary *free_thread =
|
AsanThreadSummary *free_thread =
|
||||||
asanThreadRegistry().FindByTid(m->free_tid);
|
asanThreadRegistry().FindByTid(m->free_tid);
|
||||||
Printf("freed by thread T%d here:\n", free_thread->tid());
|
Printf("freed by thread T%d here:\n", free_thread->tid());
|
||||||
AsanStackTrace free_stack;
|
StackTrace free_stack;
|
||||||
AsanStackTrace::UncompressStack(&free_stack, m->compressed_free_stack(),
|
StackTrace::UncompressStack(&free_stack, m->compressed_free_stack(),
|
||||||
m->compressed_free_stack_size());
|
m->compressed_free_stack_size());
|
||||||
free_stack.PrintStack();
|
free_stack.PrintStack();
|
||||||
Printf("previously allocated by thread T%d here:\n",
|
Printf("previously allocated by thread T%d here:\n",
|
||||||
|
@ -621,7 +621,7 @@ void DescribeHeapAddress(uptr addr, uptr access_size) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static u8 *Allocate(uptr alignment, uptr size, AsanStackTrace *stack) {
|
static u8 *Allocate(uptr alignment, uptr size, StackTrace *stack) {
|
||||||
__asan_init();
|
__asan_init();
|
||||||
CHECK(stack);
|
CHECK(stack);
|
||||||
if (size == 0) {
|
if (size == 0) {
|
||||||
|
@ -699,7 +699,7 @@ static u8 *Allocate(uptr alignment, uptr size, AsanStackTrace *stack) {
|
||||||
CHECK(m->Beg() == addr);
|
CHECK(m->Beg() == addr);
|
||||||
m->alloc_tid = t ? t->tid() : 0;
|
m->alloc_tid = t ? t->tid() : 0;
|
||||||
m->free_tid = kInvalidTid;
|
m->free_tid = kInvalidTid;
|
||||||
AsanStackTrace::CompressStack(stack, m->compressed_alloc_stack(),
|
StackTrace::CompressStack(stack, m->compressed_alloc_stack(),
|
||||||
m->compressed_alloc_stack_size());
|
m->compressed_alloc_stack_size());
|
||||||
PoisonShadow(addr, rounded_size, 0);
|
PoisonShadow(addr, rounded_size, 0);
|
||||||
if (size < rounded_size) {
|
if (size < rounded_size) {
|
||||||
|
@ -712,7 +712,7 @@ static u8 *Allocate(uptr alignment, uptr size, AsanStackTrace *stack) {
|
||||||
return (u8*)addr;
|
return (u8*)addr;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void Deallocate(u8 *ptr, AsanStackTrace *stack) {
|
static void Deallocate(u8 *ptr, StackTrace *stack) {
|
||||||
if (!ptr) return;
|
if (!ptr) return;
|
||||||
CHECK(stack);
|
CHECK(stack);
|
||||||
|
|
||||||
|
@ -739,7 +739,7 @@ static void Deallocate(u8 *ptr, AsanStackTrace *stack) {
|
||||||
CHECK(m->alloc_tid >= 0);
|
CHECK(m->alloc_tid >= 0);
|
||||||
AsanThread *t = asanThreadRegistry().GetCurrent();
|
AsanThread *t = asanThreadRegistry().GetCurrent();
|
||||||
m->free_tid = t ? t->tid() : 0;
|
m->free_tid = t ? t->tid() : 0;
|
||||||
AsanStackTrace::CompressStack(stack, m->compressed_free_stack(),
|
StackTrace::CompressStack(stack, m->compressed_free_stack(),
|
||||||
m->compressed_free_stack_size());
|
m->compressed_free_stack_size());
|
||||||
uptr rounded_size = RoundUpTo(m->used_size, REDZONE);
|
uptr rounded_size = RoundUpTo(m->used_size, REDZONE);
|
||||||
PoisonShadow((uptr)ptr, rounded_size, kAsanHeapFreeMagic);
|
PoisonShadow((uptr)ptr, rounded_size, kAsanHeapFreeMagic);
|
||||||
|
@ -765,7 +765,7 @@ static void Deallocate(u8 *ptr, AsanStackTrace *stack) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static u8 *Reallocate(u8 *old_ptr, uptr new_size,
|
static u8 *Reallocate(u8 *old_ptr, uptr new_size,
|
||||||
AsanStackTrace *stack) {
|
StackTrace *stack) {
|
||||||
CHECK(old_ptr && new_size);
|
CHECK(old_ptr && new_size);
|
||||||
|
|
||||||
// Statistics.
|
// Statistics.
|
||||||
|
@ -804,26 +804,26 @@ void __asan_free_hook(void *ptr) {
|
||||||
namespace __asan {
|
namespace __asan {
|
||||||
|
|
||||||
SANITIZER_INTERFACE_ATTRIBUTE
|
SANITIZER_INTERFACE_ATTRIBUTE
|
||||||
void *asan_memalign(uptr alignment, uptr size, AsanStackTrace *stack) {
|
void *asan_memalign(uptr alignment, uptr size, StackTrace *stack) {
|
||||||
void *ptr = (void*)Allocate(alignment, size, stack);
|
void *ptr = (void*)Allocate(alignment, size, stack);
|
||||||
__asan_malloc_hook(ptr, size);
|
__asan_malloc_hook(ptr, size);
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
SANITIZER_INTERFACE_ATTRIBUTE
|
SANITIZER_INTERFACE_ATTRIBUTE
|
||||||
void asan_free(void *ptr, AsanStackTrace *stack) {
|
void asan_free(void *ptr, StackTrace *stack) {
|
||||||
__asan_free_hook(ptr);
|
__asan_free_hook(ptr);
|
||||||
Deallocate((u8*)ptr, stack);
|
Deallocate((u8*)ptr, stack);
|
||||||
}
|
}
|
||||||
|
|
||||||
SANITIZER_INTERFACE_ATTRIBUTE
|
SANITIZER_INTERFACE_ATTRIBUTE
|
||||||
void *asan_malloc(uptr size, AsanStackTrace *stack) {
|
void *asan_malloc(uptr size, StackTrace *stack) {
|
||||||
void *ptr = (void*)Allocate(0, size, stack);
|
void *ptr = (void*)Allocate(0, size, stack);
|
||||||
__asan_malloc_hook(ptr, size);
|
__asan_malloc_hook(ptr, size);
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void *asan_calloc(uptr nmemb, uptr size, AsanStackTrace *stack) {
|
void *asan_calloc(uptr nmemb, uptr size, StackTrace *stack) {
|
||||||
void *ptr = (void*)Allocate(0, nmemb * size, stack);
|
void *ptr = (void*)Allocate(0, nmemb * size, stack);
|
||||||
if (ptr)
|
if (ptr)
|
||||||
REAL(memset)(ptr, 0, nmemb * size);
|
REAL(memset)(ptr, 0, nmemb * size);
|
||||||
|
@ -831,7 +831,7 @@ void *asan_calloc(uptr nmemb, uptr size, AsanStackTrace *stack) {
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void *asan_realloc(void *p, uptr size, AsanStackTrace *stack) {
|
void *asan_realloc(void *p, uptr size, StackTrace *stack) {
|
||||||
if (p == 0) {
|
if (p == 0) {
|
||||||
void *ptr = (void*)Allocate(0, size, stack);
|
void *ptr = (void*)Allocate(0, size, stack);
|
||||||
__asan_malloc_hook(ptr, size);
|
__asan_malloc_hook(ptr, size);
|
||||||
|
@ -844,13 +844,13 @@ void *asan_realloc(void *p, uptr size, AsanStackTrace *stack) {
|
||||||
return Reallocate((u8*)p, size, stack);
|
return Reallocate((u8*)p, size, stack);
|
||||||
}
|
}
|
||||||
|
|
||||||
void *asan_valloc(uptr size, AsanStackTrace *stack) {
|
void *asan_valloc(uptr size, StackTrace *stack) {
|
||||||
void *ptr = (void*)Allocate(kPageSize, size, stack);
|
void *ptr = (void*)Allocate(kPageSize, size, stack);
|
||||||
__asan_malloc_hook(ptr, size);
|
__asan_malloc_hook(ptr, size);
|
||||||
return ptr;
|
return ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void *asan_pvalloc(uptr size, AsanStackTrace *stack) {
|
void *asan_pvalloc(uptr size, StackTrace *stack) {
|
||||||
size = RoundUpTo(size, kPageSize);
|
size = RoundUpTo(size, kPageSize);
|
||||||
if (size == 0) {
|
if (size == 0) {
|
||||||
// pvalloc(0) should allocate one page.
|
// pvalloc(0) should allocate one page.
|
||||||
|
@ -862,7 +862,7 @@ void *asan_pvalloc(uptr size, AsanStackTrace *stack) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int asan_posix_memalign(void **memptr, uptr alignment, uptr size,
|
int asan_posix_memalign(void **memptr, uptr alignment, uptr size,
|
||||||
AsanStackTrace *stack) {
|
StackTrace *stack) {
|
||||||
void *ptr = Allocate(alignment, size, stack);
|
void *ptr = Allocate(alignment, size, stack);
|
||||||
CHECK(IsAligned((uptr)ptr, alignment));
|
CHECK(IsAligned((uptr)ptr, alignment));
|
||||||
__asan_malloc_hook(ptr, size);
|
__asan_malloc_hook(ptr, size);
|
||||||
|
@ -870,7 +870,7 @@ int asan_posix_memalign(void **memptr, uptr alignment, uptr size,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
uptr asan_malloc_usable_size(void *ptr, AsanStackTrace *stack) {
|
uptr asan_malloc_usable_size(void *ptr, StackTrace *stack) {
|
||||||
CHECK(stack);
|
CHECK(stack);
|
||||||
if (ptr == 0) return 0;
|
if (ptr == 0) return 0;
|
||||||
uptr usable_size = malloc_info.AllocationSize((uptr)ptr);
|
uptr usable_size = malloc_info.AllocationSize((uptr)ptr);
|
||||||
|
|
|
@ -137,18 +137,18 @@ class FakeStack {
|
||||||
FakeFrameLifo call_stack_;
|
FakeFrameLifo call_stack_;
|
||||||
};
|
};
|
||||||
|
|
||||||
void *asan_memalign(uptr alignment, uptr size, AsanStackTrace *stack);
|
void *asan_memalign(uptr alignment, uptr size, StackTrace *stack);
|
||||||
void asan_free(void *ptr, AsanStackTrace *stack);
|
void asan_free(void *ptr, StackTrace *stack);
|
||||||
|
|
||||||
void *asan_malloc(uptr size, AsanStackTrace *stack);
|
void *asan_malloc(uptr size, StackTrace *stack);
|
||||||
void *asan_calloc(uptr nmemb, uptr size, AsanStackTrace *stack);
|
void *asan_calloc(uptr nmemb, uptr size, StackTrace *stack);
|
||||||
void *asan_realloc(void *p, uptr size, AsanStackTrace *stack);
|
void *asan_realloc(void *p, uptr size, StackTrace *stack);
|
||||||
void *asan_valloc(uptr size, AsanStackTrace *stack);
|
void *asan_valloc(uptr size, StackTrace *stack);
|
||||||
void *asan_pvalloc(uptr size, AsanStackTrace *stack);
|
void *asan_pvalloc(uptr size, StackTrace *stack);
|
||||||
|
|
||||||
int asan_posix_memalign(void **memptr, uptr alignment, uptr size,
|
int asan_posix_memalign(void **memptr, uptr alignment, uptr size,
|
||||||
AsanStackTrace *stack);
|
StackTrace *stack);
|
||||||
uptr asan_malloc_usable_size(void *ptr, AsanStackTrace *stack);
|
uptr asan_malloc_usable_size(void *ptr, StackTrace *stack);
|
||||||
|
|
||||||
uptr asan_mz_size(const void *ptr);
|
uptr asan_mz_size(const void *ptr);
|
||||||
void asan_mz_force_lock();
|
void asan_mz_force_lock();
|
||||||
|
|
|
@ -93,7 +93,7 @@ extern "C" void* _ReturnAddress(void);
|
||||||
namespace __asan {
|
namespace __asan {
|
||||||
|
|
||||||
class AsanThread;
|
class AsanThread;
|
||||||
struct AsanStackTrace;
|
struct StackTrace;
|
||||||
|
|
||||||
// asan_rtl.cc
|
// asan_rtl.cc
|
||||||
void NORETURN ShowStatsAndAbort();
|
void NORETURN ShowStatsAndAbort();
|
||||||
|
@ -145,8 +145,6 @@ extern int asan_inited;
|
||||||
extern bool asan_init_is_running;
|
extern bool asan_init_is_running;
|
||||||
extern void (*death_callback)(void);
|
extern void (*death_callback)(void);
|
||||||
|
|
||||||
#define ASAN_ARRAY_SIZE(a) (sizeof(a)/sizeof((a)[0]))
|
|
||||||
|
|
||||||
#if !defined(_WIN32) || defined(__clang__)
|
#if !defined(_WIN32) || defined(__clang__)
|
||||||
# define GET_CALLER_PC() (uptr)__builtin_return_address(0)
|
# define GET_CALLER_PC() (uptr)__builtin_return_address(0)
|
||||||
# define GET_CURRENT_FRAME() (uptr)__builtin_frame_address(0)
|
# define GET_CURRENT_FRAME() (uptr)__builtin_frame_address(0)
|
||||||
|
|
|
@ -123,7 +123,7 @@ uptr Unwind_GetIP(struct _Unwind_Context *ctx) {
|
||||||
|
|
||||||
_Unwind_Reason_Code Unwind_Trace(struct _Unwind_Context *ctx,
|
_Unwind_Reason_Code Unwind_Trace(struct _Unwind_Context *ctx,
|
||||||
void *param) {
|
void *param) {
|
||||||
AsanStackTrace *b = (AsanStackTrace*)param;
|
StackTrace *b = (StackTrace*)param;
|
||||||
CHECK(b->size < b->max_size);
|
CHECK(b->size < b->max_size);
|
||||||
uptr pc = Unwind_GetIP(ctx);
|
uptr pc = Unwind_GetIP(ctx);
|
||||||
b->trace[b->size++] = pc;
|
b->trace[b->size++] = pc;
|
||||||
|
@ -131,7 +131,7 @@ _Unwind_Reason_Code Unwind_Trace(struct _Unwind_Context *ctx,
|
||||||
return UNWIND_CONTINUE;
|
return UNWIND_CONTINUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsanStackTrace::GetStackTrace(uptr max_s, uptr pc, uptr bp) {
|
void StackTrace::GetStackTrace(uptr max_s, uptr pc, uptr bp) {
|
||||||
size = 0;
|
size = 0;
|
||||||
trace[0] = pc;
|
trace[0] = pc;
|
||||||
if ((max_s) > 1) {
|
if ((max_s) > 1) {
|
||||||
|
|
|
@ -152,7 +152,7 @@ void AsanLock::Unlock() {
|
||||||
OSSpinLockUnlock((OSSpinLock*)&opaque_storage_);
|
OSSpinLockUnlock((OSSpinLock*)&opaque_storage_);
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsanStackTrace::GetStackTrace(uptr max_s, uptr pc, uptr bp) {
|
void StackTrace::GetStackTrace(uptr max_s, uptr pc, uptr bp) {
|
||||||
size = 0;
|
size = 0;
|
||||||
trace[0] = pc;
|
trace[0] = pc;
|
||||||
if ((max_s) > 1) {
|
if ((max_s) > 1) {
|
||||||
|
@ -280,7 +280,7 @@ int pthread_workqueue_additem_np(pthread_workqueue_t workq,
|
||||||
} // extern "C"
|
} // extern "C"
|
||||||
|
|
||||||
static ALWAYS_INLINE
|
static ALWAYS_INLINE
|
||||||
void asan_register_worker_thread(int parent_tid, AsanStackTrace *stack) {
|
void asan_register_worker_thread(int parent_tid, StackTrace *stack) {
|
||||||
AsanThread *t = asanThreadRegistry().GetCurrent();
|
AsanThread *t = asanThreadRegistry().GetCurrent();
|
||||||
if (!t) {
|
if (!t) {
|
||||||
t = AsanThread::Create(parent_tid, 0, 0, stack);
|
t = AsanThread::Create(parent_tid, 0, 0, stack);
|
||||||
|
@ -315,7 +315,7 @@ using namespace __asan; // NOLINT
|
||||||
// The caller retains control of the allocated context.
|
// The caller retains control of the allocated context.
|
||||||
extern "C"
|
extern "C"
|
||||||
asan_block_context_t *alloc_asan_context(void *ctxt, dispatch_function_t func,
|
asan_block_context_t *alloc_asan_context(void *ctxt, dispatch_function_t func,
|
||||||
AsanStackTrace *stack) {
|
StackTrace *stack) {
|
||||||
asan_block_context_t *asan_ctxt =
|
asan_block_context_t *asan_ctxt =
|
||||||
(asan_block_context_t*) asan_malloc(sizeof(asan_block_context_t), stack);
|
(asan_block_context_t*) asan_malloc(sizeof(asan_block_context_t), stack);
|
||||||
asan_ctxt->block = ctxt;
|
asan_ctxt->block = ctxt;
|
||||||
|
|
|
@ -261,14 +261,14 @@ void ReportSIGSEGV(uptr pc, uptr sp, uptr bp, uptr addr) {
|
||||||
stack.PrintStack();
|
stack.PrintStack();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReportDoubleFree(uptr addr, AsanStackTrace *stack) {
|
void ReportDoubleFree(uptr addr, StackTrace *stack) {
|
||||||
ScopedInErrorReport in_report;
|
ScopedInErrorReport in_report;
|
||||||
Report("ERROR: AddressSanitizer attempting double-free on %p:\n", addr);
|
Report("ERROR: AddressSanitizer attempting double-free on %p:\n", addr);
|
||||||
stack->PrintStack();
|
stack->PrintStack();
|
||||||
DescribeHeapAddress(addr, 1);
|
DescribeHeapAddress(addr, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReportFreeNotMalloced(uptr addr, AsanStackTrace *stack) {
|
void ReportFreeNotMalloced(uptr addr, StackTrace *stack) {
|
||||||
ScopedInErrorReport in_report;
|
ScopedInErrorReport in_report;
|
||||||
Report("ERROR: AddressSanitizer attempting free on address "
|
Report("ERROR: AddressSanitizer attempting free on address "
|
||||||
"which was not malloc()-ed: %p\n", addr);
|
"which was not malloc()-ed: %p\n", addr);
|
||||||
|
@ -276,7 +276,7 @@ void ReportFreeNotMalloced(uptr addr, AsanStackTrace *stack) {
|
||||||
DescribeHeapAddress(addr, 1);
|
DescribeHeapAddress(addr, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReportMallocUsableSizeNotOwned(uptr addr, AsanStackTrace *stack) {
|
void ReportMallocUsableSizeNotOwned(uptr addr, StackTrace *stack) {
|
||||||
ScopedInErrorReport in_report;
|
ScopedInErrorReport in_report;
|
||||||
Report("ERROR: AddressSanitizer attempting to call "
|
Report("ERROR: AddressSanitizer attempting to call "
|
||||||
"malloc_usable_size() for pointer which is "
|
"malloc_usable_size() for pointer which is "
|
||||||
|
@ -285,7 +285,7 @@ void ReportMallocUsableSizeNotOwned(uptr addr, AsanStackTrace *stack) {
|
||||||
DescribeHeapAddress(addr, 1);
|
DescribeHeapAddress(addr, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReportAsanGetAllocatedSizeNotOwned(uptr addr, AsanStackTrace *stack) {
|
void ReportAsanGetAllocatedSizeNotOwned(uptr addr, StackTrace *stack) {
|
||||||
ScopedInErrorReport in_report;
|
ScopedInErrorReport in_report;
|
||||||
Report("ERROR: AddressSanitizer attempting to call "
|
Report("ERROR: AddressSanitizer attempting to call "
|
||||||
"__asan_get_allocated_size() for pointer which is "
|
"__asan_get_allocated_size() for pointer which is "
|
||||||
|
@ -296,7 +296,7 @@ void ReportAsanGetAllocatedSizeNotOwned(uptr addr, AsanStackTrace *stack) {
|
||||||
|
|
||||||
void ReportStringFunctionMemoryRangesOverlap(
|
void ReportStringFunctionMemoryRangesOverlap(
|
||||||
const char *function, const char *offset1, uptr length1,
|
const char *function, const char *offset1, uptr length1,
|
||||||
const char *offset2, uptr length2, AsanStackTrace *stack) {
|
const char *offset2, uptr length2, StackTrace *stack) {
|
||||||
ScopedInErrorReport in_report;
|
ScopedInErrorReport in_report;
|
||||||
Report("ERROR: AddressSanitizer %s-param-overlap: "
|
Report("ERROR: AddressSanitizer %s-param-overlap: "
|
||||||
"memory ranges [%p,%p) and [%p, %p) overlap\n", \
|
"memory ranges [%p,%p) and [%p, %p) overlap\n", \
|
||||||
|
@ -309,7 +309,7 @@ void ReportStringFunctionMemoryRangesOverlap(
|
||||||
// ----------------------- Mac-specific reports ----------------- {{{1
|
// ----------------------- Mac-specific reports ----------------- {{{1
|
||||||
|
|
||||||
void WarnMacFreeUnallocated(
|
void WarnMacFreeUnallocated(
|
||||||
uptr addr, uptr zone_ptr, const char *zone_name, AsanStackTrace *stack) {
|
uptr addr, uptr zone_ptr, const char *zone_name, StackTrace *stack) {
|
||||||
// Just print a warning here.
|
// Just print a warning here.
|
||||||
Printf("free_common(%p) -- attempting to free unallocated memory.\n"
|
Printf("free_common(%p) -- attempting to free unallocated memory.\n"
|
||||||
"AddressSanitizer is ignoring this error on Mac OS now.\n",
|
"AddressSanitizer is ignoring this error on Mac OS now.\n",
|
||||||
|
@ -320,7 +320,7 @@ void WarnMacFreeUnallocated(
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReportMacMzReallocUnknown(
|
void ReportMacMzReallocUnknown(
|
||||||
uptr addr, uptr zone_ptr, const char *zone_name, AsanStackTrace *stack) {
|
uptr addr, uptr zone_ptr, const char *zone_name, StackTrace *stack) {
|
||||||
ScopedInErrorReport in_report;
|
ScopedInErrorReport in_report;
|
||||||
Printf("mz_realloc(%p) -- attempting to realloc unallocated memory.\n"
|
Printf("mz_realloc(%p) -- attempting to realloc unallocated memory.\n"
|
||||||
"This is an unrecoverable problem, exiting now.\n",
|
"This is an unrecoverable problem, exiting now.\n",
|
||||||
|
@ -331,7 +331,7 @@ void ReportMacMzReallocUnknown(
|
||||||
}
|
}
|
||||||
|
|
||||||
void ReportMacCfReallocUnknown(
|
void ReportMacCfReallocUnknown(
|
||||||
uptr addr, uptr zone_ptr, const char *zone_name, AsanStackTrace *stack) {
|
uptr addr, uptr zone_ptr, const char *zone_name, StackTrace *stack) {
|
||||||
ScopedInErrorReport in_report;
|
ScopedInErrorReport in_report;
|
||||||
Printf("cf_realloc(%p) -- attempting to realloc unallocated memory.\n"
|
Printf("cf_realloc(%p) -- attempting to realloc unallocated memory.\n"
|
||||||
"This is an unrecoverable problem, exiting now.\n",
|
"This is an unrecoverable problem, exiting now.\n",
|
||||||
|
|
|
@ -29,22 +29,22 @@ void DescribeAddress(uptr addr, uptr access_size);
|
||||||
|
|
||||||
// Different kinds of error reports.
|
// Different kinds of error reports.
|
||||||
void NORETURN ReportSIGSEGV(uptr pc, uptr sp, uptr bp, uptr addr);
|
void NORETURN ReportSIGSEGV(uptr pc, uptr sp, uptr bp, uptr addr);
|
||||||
void NORETURN ReportDoubleFree(uptr addr, AsanStackTrace *stack);
|
void NORETURN ReportDoubleFree(uptr addr, StackTrace *stack);
|
||||||
void NORETURN ReportFreeNotMalloced(uptr addr, AsanStackTrace *stack);
|
void NORETURN ReportFreeNotMalloced(uptr addr, StackTrace *stack);
|
||||||
void NORETURN ReportMallocUsableSizeNotOwned(uptr addr,
|
void NORETURN ReportMallocUsableSizeNotOwned(uptr addr,
|
||||||
AsanStackTrace *stack);
|
StackTrace *stack);
|
||||||
void NORETURN ReportAsanGetAllocatedSizeNotOwned(uptr addr,
|
void NORETURN ReportAsanGetAllocatedSizeNotOwned(uptr addr,
|
||||||
AsanStackTrace *stack);
|
StackTrace *stack);
|
||||||
void NORETURN ReportStringFunctionMemoryRangesOverlap(
|
void NORETURN ReportStringFunctionMemoryRangesOverlap(
|
||||||
const char *function, const char *offset1, uptr length1,
|
const char *function, const char *offset1, uptr length1,
|
||||||
const char *offset2, uptr length2, AsanStackTrace *stack);
|
const char *offset2, uptr length2, StackTrace *stack);
|
||||||
|
|
||||||
// Mac-specific errors and warnings.
|
// Mac-specific errors and warnings.
|
||||||
void WarnMacFreeUnallocated(
|
void WarnMacFreeUnallocated(
|
||||||
uptr addr, uptr zone_ptr, const char *zone_name, AsanStackTrace *stack);
|
uptr addr, uptr zone_ptr, const char *zone_name, StackTrace *stack);
|
||||||
void NORETURN ReportMacMzReallocUnknown(
|
void NORETURN ReportMacMzReallocUnknown(
|
||||||
uptr addr, uptr zone_ptr, const char *zone_name, AsanStackTrace *stack);
|
uptr addr, uptr zone_ptr, const char *zone_name, StackTrace *stack);
|
||||||
void NORETURN ReportMacCfReallocUnknown(
|
void NORETURN ReportMacCfReallocUnknown(
|
||||||
uptr addr, uptr zone_ptr, const char *zone_name, AsanStackTrace *stack);
|
uptr addr, uptr zone_ptr, const char *zone_name, StackTrace *stack);
|
||||||
|
|
||||||
} // namespace __asan
|
} // namespace __asan
|
||||||
|
|
|
@ -31,7 +31,7 @@ static const char *StripPathPrefix(const char *filepath) {
|
||||||
return filepath;
|
return filepath;
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------- AsanStackTrace ----------------------------- {{{1
|
// ----------------------- StackTrace ----------------------------- {{{1
|
||||||
// PCs in stack traces are actually the return addresses, that is,
|
// PCs in stack traces are actually the return addresses, that is,
|
||||||
// addresses of the next instructions after the call. That's why we
|
// addresses of the next instructions after the call. That's why we
|
||||||
// decrement them.
|
// decrement them.
|
||||||
|
@ -43,7 +43,7 @@ static uptr patch_pc(uptr pc) {
|
||||||
return pc - 1;
|
return pc - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsanStackTrace::PrintStack(uptr *addr, uptr size) {
|
void StackTrace::PrintStack(uptr *addr, uptr size) {
|
||||||
MemoryMappingLayout proc_maps;
|
MemoryMappingLayout proc_maps;
|
||||||
uptr frame_num = 0;
|
uptr frame_num = 0;
|
||||||
for (uptr i = 0; i < size && addr[i]; i++) {
|
for (uptr i = 0; i < size && addr[i]; i++) {
|
||||||
|
@ -61,8 +61,7 @@ void AsanStackTrace::PrintStack(uptr *addr, uptr size) {
|
||||||
AddressInfo addr_frames[64];
|
AddressInfo addr_frames[64];
|
||||||
uptr addr_frames_num = 0;
|
uptr addr_frames_num = 0;
|
||||||
if (flags()->symbolize) {
|
if (flags()->symbolize) {
|
||||||
addr_frames_num = SymbolizeCode(pc, addr_frames,
|
addr_frames_num = SymbolizeCode(pc, addr_frames, ARRAY_SIZE(addr_frames));
|
||||||
ASAN_ARRAY_SIZE(addr_frames));
|
|
||||||
}
|
}
|
||||||
if (addr_frames_num > 0) {
|
if (addr_frames_num > 0) {
|
||||||
for (uptr j = 0; j < addr_frames_num; j++) {
|
for (uptr j = 0; j < addr_frames_num; j++) {
|
||||||
|
@ -97,11 +96,11 @@ void AsanStackTrace::PrintStack(uptr *addr, uptr size) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
uptr AsanStackTrace::GetCurrentPc() {
|
uptr StackTrace::GetCurrentPc() {
|
||||||
return GET_CALLER_PC();
|
return GET_CALLER_PC();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AsanStackTrace::FastUnwindStack(uptr pc, uptr bp) {
|
void StackTrace::FastUnwindStack(uptr pc, uptr bp) {
|
||||||
CHECK(size == 0 && trace[0] == pc);
|
CHECK(size == 0 && trace[0] == pc);
|
||||||
size = 1;
|
size = 1;
|
||||||
if (!asan_inited) return;
|
if (!asan_inited) return;
|
||||||
|
@ -128,8 +127,7 @@ void AsanStackTrace::FastUnwindStack(uptr pc, uptr bp) {
|
||||||
// On 64-bits we compress stack traces: if a given pc differes slightly from
|
// On 64-bits we compress stack traces: if a given pc differes slightly from
|
||||||
// the previous one, we record a 31-bit offset instead of the full pc.
|
// the previous one, we record a 31-bit offset instead of the full pc.
|
||||||
SANITIZER_INTERFACE_ATTRIBUTE
|
SANITIZER_INTERFACE_ATTRIBUTE
|
||||||
uptr AsanStackTrace::CompressStack(AsanStackTrace *stack,
|
uptr StackTrace::CompressStack(StackTrace *stack, u32 *compressed, uptr size) {
|
||||||
u32 *compressed, uptr size) {
|
|
||||||
#if __WORDSIZE == 32
|
#if __WORDSIZE == 32
|
||||||
// Don't compress, just copy.
|
// Don't compress, just copy.
|
||||||
uptr res = 0;
|
uptr res = 0;
|
||||||
|
@ -175,7 +173,7 @@ uptr AsanStackTrace::CompressStack(AsanStackTrace *stack,
|
||||||
|
|
||||||
// debug-only code
|
// debug-only code
|
||||||
#if 0
|
#if 0
|
||||||
AsanStackTrace check_stack;
|
StackTrace check_stack;
|
||||||
UncompressStack(&check_stack, compressed, size);
|
UncompressStack(&check_stack, compressed, size);
|
||||||
if (res < check_stack.size) {
|
if (res < check_stack.size) {
|
||||||
Printf("res %zu check_stack.size %zu; c_size %zu\n", res,
|
Printf("res %zu check_stack.size %zu; c_size %zu\n", res,
|
||||||
|
@ -192,7 +190,7 @@ uptr AsanStackTrace::CompressStack(AsanStackTrace *stack,
|
||||||
}
|
}
|
||||||
|
|
||||||
SANITIZER_INTERFACE_ATTRIBUTE
|
SANITIZER_INTERFACE_ATTRIBUTE
|
||||||
void AsanStackTrace::UncompressStack(AsanStackTrace *stack,
|
void StackTrace::UncompressStack(StackTrace *stack,
|
||||||
u32 *compressed, uptr size) {
|
u32 *compressed, uptr size) {
|
||||||
#if __WORDSIZE == 32
|
#if __WORDSIZE == 32
|
||||||
// Don't uncompress, just copy.
|
// Don't uncompress, just copy.
|
||||||
|
|
|
@ -20,7 +20,7 @@ namespace __asan {
|
||||||
|
|
||||||
static const uptr kStackTraceMax = 64;
|
static const uptr kStackTraceMax = 64;
|
||||||
|
|
||||||
struct AsanStackTrace {
|
struct StackTrace {
|
||||||
uptr size;
|
uptr size;
|
||||||
uptr max_size;
|
uptr max_size;
|
||||||
uptr trace[kStackTraceMax];
|
uptr trace[kStackTraceMax];
|
||||||
|
@ -49,9 +49,9 @@ struct AsanStackTrace {
|
||||||
|
|
||||||
static uptr GetCurrentPc();
|
static uptr GetCurrentPc();
|
||||||
|
|
||||||
static uptr CompressStack(AsanStackTrace *stack,
|
static uptr CompressStack(StackTrace *stack,
|
||||||
u32 *compressed, uptr size);
|
u32 *compressed, uptr size);
|
||||||
static void UncompressStack(AsanStackTrace *stack,
|
static void UncompressStack(StackTrace *stack,
|
||||||
u32 *compressed, uptr size);
|
u32 *compressed, uptr size);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -69,7 +69,7 @@ struct AsanStackTrace {
|
||||||
// function in the top frame.
|
// function in the top frame.
|
||||||
#define GET_CURRENT_PC_BP_SP \
|
#define GET_CURRENT_PC_BP_SP \
|
||||||
uptr bp = GET_CURRENT_FRAME(); \
|
uptr bp = GET_CURRENT_FRAME(); \
|
||||||
uptr pc = AsanStackTrace::GetCurrentPc(); \
|
uptr pc = StackTrace::GetCurrentPc(); \
|
||||||
uptr local_stack; \
|
uptr local_stack; \
|
||||||
uptr sp = (uptr)&local_stack
|
uptr sp = (uptr)&local_stack
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ struct AsanStackTrace {
|
||||||
// The bp may refer to the current frame or to the caller's frame.
|
// The bp may refer to the current frame or to the caller's frame.
|
||||||
// fast_unwind is currently unused.
|
// fast_unwind is currently unused.
|
||||||
#define GET_STACK_TRACE_WITH_PC_AND_BP(max_s, pc, bp) \
|
#define GET_STACK_TRACE_WITH_PC_AND_BP(max_s, pc, bp) \
|
||||||
AsanStackTrace stack; \
|
StackTrace stack; \
|
||||||
stack.GetStackTrace(max_s, pc, bp)
|
stack.GetStackTrace(max_s, pc, bp)
|
||||||
|
|
||||||
// NOTE: A Rule of thumb is to retrieve stack trace in the interceptors
|
// NOTE: A Rule of thumb is to retrieve stack trace in the interceptors
|
||||||
|
@ -87,7 +87,7 @@ struct AsanStackTrace {
|
||||||
|
|
||||||
#define GET_STACK_TRACE_HERE(max_size) \
|
#define GET_STACK_TRACE_HERE(max_size) \
|
||||||
GET_STACK_TRACE_WITH_PC_AND_BP(max_size, \
|
GET_STACK_TRACE_WITH_PC_AND_BP(max_size, \
|
||||||
AsanStackTrace::GetCurrentPc(), GET_CURRENT_FRAME())
|
StackTrace::GetCurrentPc(), GET_CURRENT_FRAME())
|
||||||
|
|
||||||
#define GET_STACK_TRACE_HERE_FOR_MALLOC \
|
#define GET_STACK_TRACE_HERE_FOR_MALLOC \
|
||||||
GET_STACK_TRACE_HERE(flags()->malloc_context_size)
|
GET_STACK_TRACE_HERE(flags()->malloc_context_size)
|
||||||
|
|
|
@ -30,7 +30,7 @@ static AsanLock mu_for_thread_summary(LINKER_INITIALIZED);
|
||||||
static LowLevelAllocator allocator_for_thread_summary;
|
static LowLevelAllocator allocator_for_thread_summary;
|
||||||
|
|
||||||
AsanThread *AsanThread::Create(u32 parent_tid, thread_callback_t start_routine,
|
AsanThread *AsanThread::Create(u32 parent_tid, thread_callback_t start_routine,
|
||||||
void *arg, AsanStackTrace *stack) {
|
void *arg, StackTrace *stack) {
|
||||||
uptr size = RoundUpTo(sizeof(AsanThread), kPageSize);
|
uptr size = RoundUpTo(sizeof(AsanThread), kPageSize);
|
||||||
AsanThread *thread = (AsanThread*)MmapOrDie(size, __FUNCTION__);
|
AsanThread *thread = (AsanThread*)MmapOrDie(size, __FUNCTION__);
|
||||||
thread->start_routine_ = start_routine;
|
thread->start_routine_ = start_routine;
|
||||||
|
|
|
@ -31,7 +31,7 @@ class AsanThread;
|
||||||
class AsanThreadSummary {
|
class AsanThreadSummary {
|
||||||
public:
|
public:
|
||||||
explicit AsanThreadSummary(LinkerInitialized) { } // for T0.
|
explicit AsanThreadSummary(LinkerInitialized) { } // for T0.
|
||||||
void Init(u32 parent_tid, AsanStackTrace *stack) {
|
void Init(u32 parent_tid, StackTrace *stack) {
|
||||||
parent_tid_ = parent_tid;
|
parent_tid_ = parent_tid;
|
||||||
announced_ = false;
|
announced_ = false;
|
||||||
tid_ = kInvalidTid;
|
tid_ = kInvalidTid;
|
||||||
|
@ -58,7 +58,7 @@ class AsanThreadSummary {
|
||||||
u32 tid_;
|
u32 tid_;
|
||||||
u32 parent_tid_;
|
u32 parent_tid_;
|
||||||
bool announced_;
|
bool announced_;
|
||||||
AsanStackTrace stack_;
|
StackTrace stack_;
|
||||||
AsanThread *thread_;
|
AsanThread *thread_;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -67,7 +67,7 @@ class AsanThread {
|
||||||
public:
|
public:
|
||||||
explicit AsanThread(LinkerInitialized); // for T0.
|
explicit AsanThread(LinkerInitialized); // for T0.
|
||||||
static AsanThread *Create(u32 parent_tid, thread_callback_t start_routine,
|
static AsanThread *Create(u32 parent_tid, thread_callback_t start_routine,
|
||||||
void *arg, AsanStackTrace *stack);
|
void *arg, StackTrace *stack);
|
||||||
void Destroy();
|
void Destroy();
|
||||||
|
|
||||||
void Init(); // Should be called from the thread itself.
|
void Init(); // Should be called from the thread itself.
|
||||||
|
|
|
@ -32,7 +32,7 @@ static AsanLock dbghelp_lock(LINKER_INITIALIZED);
|
||||||
static bool dbghelp_initialized = false;
|
static bool dbghelp_initialized = false;
|
||||||
#pragma comment(lib, "dbghelp.lib")
|
#pragma comment(lib, "dbghelp.lib")
|
||||||
|
|
||||||
void AsanStackTrace::GetStackTrace(uptr max_s, uptr pc, uptr bp) {
|
void StackTrace::GetStackTrace(uptr max_s, uptr pc, uptr bp) {
|
||||||
max_size = max_s;
|
max_size = max_s;
|
||||||
void *tmp[kStackTraceMax];
|
void *tmp[kStackTraceMax];
|
||||||
|
|
||||||
|
|
|
@ -42,17 +42,17 @@ TEST(AddressSanitizer, InternalSimpleDeathTest) {
|
||||||
|
|
||||||
static void MallocStress(size_t n) {
|
static void MallocStress(size_t n) {
|
||||||
u32 seed = my_rand(&global_seed);
|
u32 seed = my_rand(&global_seed);
|
||||||
__asan::AsanStackTrace stack1;
|
__asan::StackTrace stack1;
|
||||||
stack1.trace[0] = 0xa123;
|
stack1.trace[0] = 0xa123;
|
||||||
stack1.trace[1] = 0xa456;
|
stack1.trace[1] = 0xa456;
|
||||||
stack1.size = 2;
|
stack1.size = 2;
|
||||||
|
|
||||||
__asan::AsanStackTrace stack2;
|
__asan::StackTrace stack2;
|
||||||
stack2.trace[0] = 0xb123;
|
stack2.trace[0] = 0xb123;
|
||||||
stack2.trace[1] = 0xb456;
|
stack2.trace[1] = 0xb456;
|
||||||
stack2.size = 2;
|
stack2.size = 2;
|
||||||
|
|
||||||
__asan::AsanStackTrace stack3;
|
__asan::StackTrace stack3;
|
||||||
stack3.trace[0] = 0xc123;
|
stack3.trace[0] = 0xc123;
|
||||||
stack3.trace[1] = 0xc456;
|
stack3.trace[1] = 0xc456;
|
||||||
stack3.size = 2;
|
stack3.size = 2;
|
||||||
|
@ -210,21 +210,21 @@ static uptr pc_array[] = {
|
||||||
|
|
||||||
void CompressStackTraceTest(size_t n_iter) {
|
void CompressStackTraceTest(size_t n_iter) {
|
||||||
u32 seed = my_rand(&global_seed);
|
u32 seed = my_rand(&global_seed);
|
||||||
const size_t kNumPcs = ASAN_ARRAY_SIZE(pc_array);
|
const size_t kNumPcs = ARRAY_SIZE(pc_array);
|
||||||
u32 compressed[2 * kNumPcs];
|
u32 compressed[2 * kNumPcs];
|
||||||
|
|
||||||
for (size_t iter = 0; iter < n_iter; iter++) {
|
for (size_t iter = 0; iter < n_iter; iter++) {
|
||||||
std::random_shuffle(pc_array, pc_array + kNumPcs);
|
std::random_shuffle(pc_array, pc_array + kNumPcs);
|
||||||
__asan::AsanStackTrace stack0, stack1;
|
__asan::StackTrace stack0, stack1;
|
||||||
stack0.CopyFrom(pc_array, kNumPcs);
|
stack0.CopyFrom(pc_array, kNumPcs);
|
||||||
stack0.size = std::max((size_t)1, (size_t)(my_rand(&seed) % stack0.size));
|
stack0.size = std::max((size_t)1, (size_t)(my_rand(&seed) % stack0.size));
|
||||||
size_t compress_size =
|
size_t compress_size =
|
||||||
std::max((size_t)2, (size_t)my_rand(&seed) % (2 * kNumPcs));
|
std::max((size_t)2, (size_t)my_rand(&seed) % (2 * kNumPcs));
|
||||||
size_t n_frames =
|
size_t n_frames =
|
||||||
__asan::AsanStackTrace::CompressStack(&stack0, compressed, compress_size);
|
__asan::StackTrace::CompressStack(&stack0, compressed, compress_size);
|
||||||
Ident(n_frames);
|
Ident(n_frames);
|
||||||
assert(n_frames <= stack0.size);
|
assert(n_frames <= stack0.size);
|
||||||
__asan::AsanStackTrace::UncompressStack(&stack1, compressed, compress_size);
|
__asan::StackTrace::UncompressStack(&stack1, compressed, compress_size);
|
||||||
assert(stack1.size == n_frames);
|
assert(stack1.size == n_frames);
|
||||||
for (size_t i = 0; i < stack1.size; i++) {
|
for (size_t i = 0; i < stack1.size; i++) {
|
||||||
assert(stack0.trace[i] == stack1.trace[i]);
|
assert(stack0.trace[i] == stack1.trace[i]);
|
||||||
|
@ -237,17 +237,17 @@ TEST(AddressSanitizer, CompressStackTraceTest) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void CompressStackTraceBenchmark(size_t n_iter) {
|
void CompressStackTraceBenchmark(size_t n_iter) {
|
||||||
const size_t kNumPcs = ASAN_ARRAY_SIZE(pc_array);
|
const size_t kNumPcs = ARRAY_SIZE(pc_array);
|
||||||
u32 compressed[2 * kNumPcs];
|
u32 compressed[2 * kNumPcs];
|
||||||
std::random_shuffle(pc_array, pc_array + kNumPcs);
|
std::random_shuffle(pc_array, pc_array + kNumPcs);
|
||||||
|
|
||||||
__asan::AsanStackTrace stack0;
|
__asan::StackTrace stack0;
|
||||||
stack0.CopyFrom(pc_array, kNumPcs);
|
stack0.CopyFrom(pc_array, kNumPcs);
|
||||||
stack0.size = kNumPcs;
|
stack0.size = kNumPcs;
|
||||||
for (size_t iter = 0; iter < n_iter; iter++) {
|
for (size_t iter = 0; iter < n_iter; iter++) {
|
||||||
size_t compress_size = kNumPcs;
|
size_t compress_size = kNumPcs;
|
||||||
size_t n_frames =
|
size_t n_frames =
|
||||||
__asan::AsanStackTrace::CompressStack(&stack0, compressed, compress_size);
|
__asan::StackTrace::CompressStack(&stack0, compressed, compress_size);
|
||||||
Ident(n_frames);
|
Ident(n_frames);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -257,7 +257,7 @@ TEST(AddressSanitizer, CompressStackTraceBenchmark) {
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST(AddressSanitizer, QuarantineTest) {
|
TEST(AddressSanitizer, QuarantineTest) {
|
||||||
__asan::AsanStackTrace stack;
|
__asan::StackTrace stack;
|
||||||
stack.trace[0] = 0x890;
|
stack.trace[0] = 0x890;
|
||||||
stack.size = 1;
|
stack.size = 1;
|
||||||
|
|
||||||
|
@ -279,7 +279,7 @@ TEST(AddressSanitizer, QuarantineTest) {
|
||||||
void *ThreadedQuarantineTestWorker(void *unused) {
|
void *ThreadedQuarantineTestWorker(void *unused) {
|
||||||
(void)unused;
|
(void)unused;
|
||||||
u32 seed = my_rand(&global_seed);
|
u32 seed = my_rand(&global_seed);
|
||||||
__asan::AsanStackTrace stack;
|
__asan::StackTrace stack;
|
||||||
stack.trace[0] = 0x890;
|
stack.trace[0] = 0x890;
|
||||||
stack.size = 1;
|
stack.size = 1;
|
||||||
|
|
||||||
|
@ -306,7 +306,7 @@ TEST(AddressSanitizer, ThreadedQuarantineTest) {
|
||||||
|
|
||||||
void *ThreadedOneSizeMallocStress(void *unused) {
|
void *ThreadedOneSizeMallocStress(void *unused) {
|
||||||
(void)unused;
|
(void)unused;
|
||||||
__asan::AsanStackTrace stack;
|
__asan::StackTrace stack;
|
||||||
stack.trace[0] = 0x890;
|
stack.trace[0] = 0x890;
|
||||||
stack.size = 1;
|
stack.size = 1;
|
||||||
const size_t kNumMallocs = 1000;
|
const size_t kNumMallocs = 1000;
|
||||||
|
|
Loading…
Reference in New Issue