forked from OSchip/llvm-project
[ASan] Minor ASan error reporting cleanup
Summary: - use proper Error() decorator for error messages - refactor ASan thread id and name reporting Reviewers: eugenis Subscribers: kubamracek, delcypher, #sanitizers, llvm-commits Differential Revision: https://reviews.llvm.org/D49044 llvm-svn: 336573
This commit is contained in:
parent
29a07b37bf
commit
63af91574f
|
@ -20,23 +20,25 @@
|
||||||
|
|
||||||
namespace __asan {
|
namespace __asan {
|
||||||
|
|
||||||
// Return " (thread_name) " or an empty string if the name is empty.
|
AsanThreadIdAndName::AsanThreadIdAndName(AsanThreadContext *t) {
|
||||||
const char *ThreadNameWithParenthesis(AsanThreadContext *t, char buff[],
|
Init(t->tid, t->name);
|
||||||
uptr buff_len) {
|
|
||||||
const char *name = t->name;
|
|
||||||
if (name[0] == '\0') return "";
|
|
||||||
buff[0] = 0;
|
|
||||||
internal_strncat(buff, " (", 3);
|
|
||||||
internal_strncat(buff, name, buff_len - 4);
|
|
||||||
internal_strncat(buff, ")", 2);
|
|
||||||
return buff;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *ThreadNameWithParenthesis(u32 tid, char buff[], uptr buff_len) {
|
AsanThreadIdAndName::AsanThreadIdAndName(u32 tid) {
|
||||||
if (tid == kInvalidTid) return "";
|
if (tid == kInvalidTid) {
|
||||||
|
Init(tid, "");
|
||||||
|
} else {
|
||||||
asanThreadRegistry().CheckLocked();
|
asanThreadRegistry().CheckLocked();
|
||||||
AsanThreadContext *t = GetThreadContextByTidLocked(tid);
|
AsanThreadContext *t = GetThreadContextByTidLocked(tid);
|
||||||
return ThreadNameWithParenthesis(t, buff, buff_len);
|
Init(tid, t->name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AsanThreadIdAndName::Init(u32 tid, const char *tname) {
|
||||||
|
int len = internal_snprintf(name, sizeof(name), "T%d", tid);
|
||||||
|
CHECK(((unsigned int)len) < sizeof(name));
|
||||||
|
if (tname[0] != '\0')
|
||||||
|
internal_snprintf(&name[len], sizeof(name) - len, " (%s)", tname);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DescribeThread(AsanThreadContext *context) {
|
void DescribeThread(AsanThreadContext *context) {
|
||||||
|
@ -47,18 +49,15 @@ void DescribeThread(AsanThreadContext *context) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
context->announced = true;
|
context->announced = true;
|
||||||
char tname[128];
|
|
||||||
InternalScopedString str(1024);
|
InternalScopedString str(1024);
|
||||||
str.append("Thread T%d%s", context->tid,
|
str.append("Thread %s", AsanThreadIdAndName(context).c_str());
|
||||||
ThreadNameWithParenthesis(context->tid, tname, sizeof(tname)));
|
|
||||||
if (context->parent_tid == kInvalidTid) {
|
if (context->parent_tid == kInvalidTid) {
|
||||||
str.append(" created by unknown thread\n");
|
str.append(" created by unknown thread\n");
|
||||||
Printf("%s", str.data());
|
Printf("%s", str.data());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
str.append(
|
str.append(" created by %s here:\n",
|
||||||
" created by T%d%s here:\n", context->parent_tid,
|
AsanThreadIdAndName(context->parent_tid).c_str());
|
||||||
ThreadNameWithParenthesis(context->parent_tid, tname, sizeof(tname)));
|
|
||||||
Printf("%s", str.data());
|
Printf("%s", str.data());
|
||||||
StackDepotGet(context->stack_id).Print();
|
StackDepotGet(context->stack_id).Print();
|
||||||
// Recursively described parent thread if needed.
|
// Recursively described parent thread if needed.
|
||||||
|
@ -358,10 +357,9 @@ bool GlobalAddressDescription::PointsInsideTheSameVariable(
|
||||||
|
|
||||||
void StackAddressDescription::Print() const {
|
void StackAddressDescription::Print() const {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
char tname[128];
|
|
||||||
Printf("%s", d.Location());
|
Printf("%s", d.Location());
|
||||||
Printf("Address %p is located in stack of thread T%d%s", addr, tid,
|
Printf("Address %p is located in stack of thread %s", addr,
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
AsanThreadIdAndName(tid).c_str());
|
||||||
|
|
||||||
if (!frame_descr) {
|
if (!frame_descr) {
|
||||||
Printf("%s\n", d.Default());
|
Printf("%s\n", d.Default());
|
||||||
|
@ -419,26 +417,19 @@ void HeapAddressDescription::Print() const {
|
||||||
AsanThreadContext *alloc_thread = GetThreadContextByTidLocked(alloc_tid);
|
AsanThreadContext *alloc_thread = GetThreadContextByTidLocked(alloc_tid);
|
||||||
StackTrace alloc_stack = GetStackTraceFromId(alloc_stack_id);
|
StackTrace alloc_stack = GetStackTraceFromId(alloc_stack_id);
|
||||||
|
|
||||||
char tname[128];
|
|
||||||
Decorator d;
|
Decorator d;
|
||||||
AsanThreadContext *free_thread = nullptr;
|
AsanThreadContext *free_thread = nullptr;
|
||||||
if (free_tid != kInvalidTid) {
|
if (free_tid != kInvalidTid) {
|
||||||
free_thread = GetThreadContextByTidLocked(free_tid);
|
free_thread = GetThreadContextByTidLocked(free_tid);
|
||||||
Printf("%sfreed by thread T%d%s here:%s\n", d.Allocation(),
|
Printf("%sfreed by thread %s here:%s\n", d.Allocation(),
|
||||||
free_thread->tid,
|
AsanThreadIdAndName(free_thread).c_str(), d.Default());
|
||||||
ThreadNameWithParenthesis(free_thread, tname, sizeof(tname)),
|
|
||||||
d.Default());
|
|
||||||
StackTrace free_stack = GetStackTraceFromId(free_stack_id);
|
StackTrace free_stack = GetStackTraceFromId(free_stack_id);
|
||||||
free_stack.Print();
|
free_stack.Print();
|
||||||
Printf("%spreviously allocated by thread T%d%s here:%s\n", d.Allocation(),
|
Printf("%spreviously allocated by thread %s here:%s\n", d.Allocation(),
|
||||||
alloc_thread->tid,
|
AsanThreadIdAndName(alloc_thread).c_str(), d.Default());
|
||||||
ThreadNameWithParenthesis(alloc_thread, tname, sizeof(tname)),
|
|
||||||
d.Default());
|
|
||||||
} else {
|
} else {
|
||||||
Printf("%sallocated by thread T%d%s here:%s\n", d.Allocation(),
|
Printf("%sallocated by thread %s here:%s\n", d.Allocation(),
|
||||||
alloc_thread->tid,
|
AsanThreadIdAndName(alloc_thread).c_str(), d.Default());
|
||||||
ThreadNameWithParenthesis(alloc_thread, tname, sizeof(tname)),
|
|
||||||
d.Default());
|
|
||||||
}
|
}
|
||||||
alloc_stack.Print();
|
alloc_stack.Print();
|
||||||
DescribeThread(GetCurrentThread());
|
DescribeThread(GetCurrentThread());
|
||||||
|
|
|
@ -26,9 +26,20 @@ void DescribeThread(AsanThreadContext *context);
|
||||||
static inline void DescribeThread(AsanThread *t) {
|
static inline void DescribeThread(AsanThread *t) {
|
||||||
if (t) DescribeThread(t->context());
|
if (t) DescribeThread(t->context());
|
||||||
}
|
}
|
||||||
const char *ThreadNameWithParenthesis(AsanThreadContext *t, char buff[],
|
|
||||||
uptr buff_len);
|
class AsanThreadIdAndName {
|
||||||
const char *ThreadNameWithParenthesis(u32 tid, char buff[], uptr buff_len);
|
public:
|
||||||
|
explicit AsanThreadIdAndName(AsanThreadContext *t);
|
||||||
|
explicit AsanThreadIdAndName(u32 tid);
|
||||||
|
|
||||||
|
// Contains "T%tid (%name)" or "T%tid" if the name is empty.
|
||||||
|
const char *c_str() const { return &name[0]; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
void Init(u32 tid, const char *tname);
|
||||||
|
|
||||||
|
char name[128];
|
||||||
|
};
|
||||||
|
|
||||||
class Decorator : public __sanitizer::SanitizerCommonDecorator {
|
class Decorator : public __sanitizer::SanitizerCommonDecorator {
|
||||||
public:
|
public:
|
||||||
|
|
|
@ -45,13 +45,11 @@ void ErrorDeadlySignal::Print() {
|
||||||
|
|
||||||
void ErrorDoubleFree::Print() {
|
void ErrorDoubleFree::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: attempting %s on %p in "
|
"ERROR: AddressSanitizer: attempting %s on %p in thread %s:\n",
|
||||||
"thread T%d%s:\n",
|
scariness.GetDescription(), addr_description.addr,
|
||||||
scariness.GetDescription(), addr_description.addr, tid,
|
AsanThreadIdAndName(tid).c_str());
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
scariness.Print();
|
scariness.Print();
|
||||||
GET_STACK_TRACE_FATAL(second_free_stack->trace[0],
|
GET_STACK_TRACE_FATAL(second_free_stack->trace[0],
|
||||||
|
@ -63,13 +61,11 @@ void ErrorDoubleFree::Print() {
|
||||||
|
|
||||||
void ErrorNewDeleteTypeMismatch::Print() {
|
void ErrorNewDeleteTypeMismatch::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: %s on %p in thread "
|
"ERROR: AddressSanitizer: %s on %p in thread %s:\n",
|
||||||
"T%d%s:\n",
|
scariness.GetDescription(), addr_description.addr,
|
||||||
scariness.GetDescription(), addr_description.addr, tid,
|
AsanThreadIdAndName(tid).c_str());
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
|
||||||
Printf("%s object passed to delete has wrong type:\n", d.Default());
|
Printf("%s object passed to delete has wrong type:\n", d.Default());
|
||||||
if (delete_size != 0) {
|
if (delete_size != 0) {
|
||||||
Printf(
|
Printf(
|
||||||
|
@ -106,13 +102,11 @@ void ErrorNewDeleteTypeMismatch::Print() {
|
||||||
|
|
||||||
void ErrorFreeNotMalloced::Print() {
|
void ErrorFreeNotMalloced::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: attempting free on address "
|
"ERROR: AddressSanitizer: attempting free on address "
|
||||||
"which was not malloc()-ed: %p in thread T%d%s\n",
|
"which was not malloc()-ed: %p in thread %s\n",
|
||||||
addr_description.Address(), tid,
|
addr_description.Address(), AsanThreadIdAndName(tid).c_str());
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
CHECK_GT(free_stack->size, 0);
|
CHECK_GT(free_stack->size, 0);
|
||||||
scariness.Print();
|
scariness.Print();
|
||||||
|
@ -129,7 +123,7 @@ void ErrorAllocTypeMismatch::Print() {
|
||||||
"operator delete []"};
|
"operator delete []"};
|
||||||
CHECK_NE(alloc_type, dealloc_type);
|
CHECK_NE(alloc_type, dealloc_type);
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report("ERROR: AddressSanitizer: %s (%s vs %s) on %p\n",
|
Report("ERROR: AddressSanitizer: %s (%s vs %s) on %p\n",
|
||||||
scariness.GetDescription(),
|
scariness.GetDescription(),
|
||||||
alloc_names[alloc_type], dealloc_names[dealloc_type],
|
alloc_names[alloc_type], dealloc_names[dealloc_type],
|
||||||
|
@ -148,7 +142,7 @@ void ErrorAllocTypeMismatch::Print() {
|
||||||
|
|
||||||
void ErrorMallocUsableSizeNotOwned::Print() {
|
void ErrorMallocUsableSizeNotOwned::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: attempting to call malloc_usable_size() for "
|
"ERROR: AddressSanitizer: attempting to call malloc_usable_size() for "
|
||||||
"pointer which is not owned: %p\n",
|
"pointer which is not owned: %p\n",
|
||||||
|
@ -161,7 +155,7 @@ void ErrorMallocUsableSizeNotOwned::Print() {
|
||||||
|
|
||||||
void ErrorSanitizerGetAllocatedSizeNotOwned::Print() {
|
void ErrorSanitizerGetAllocatedSizeNotOwned::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: attempting to call "
|
"ERROR: AddressSanitizer: attempting to call "
|
||||||
"__sanitizer_get_allocated_size() for pointer which is not owned: %p\n",
|
"__sanitizer_get_allocated_size() for pointer which is not owned: %p\n",
|
||||||
|
@ -174,12 +168,11 @@ void ErrorSanitizerGetAllocatedSizeNotOwned::Print() {
|
||||||
|
|
||||||
void ErrorCallocOverflow::Print() {
|
void ErrorCallocOverflow::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: calloc parameters overflow: count * size "
|
"ERROR: AddressSanitizer: calloc parameters overflow: count * size "
|
||||||
"(%zd * %zd) cannot be represented in type size_t (thread T%d%s)\n",
|
"(%zd * %zd) cannot be represented in type size_t (thread %s)\n",
|
||||||
count, size, tid, ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
count, size, AsanThreadIdAndName(tid).c_str());
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
stack->Print();
|
stack->Print();
|
||||||
PrintHintAllocatorCannotReturnNull();
|
PrintHintAllocatorCannotReturnNull();
|
||||||
|
@ -188,14 +181,12 @@ void ErrorCallocOverflow::Print() {
|
||||||
|
|
||||||
void ErrorPvallocOverflow::Print() {
|
void ErrorPvallocOverflow::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: pvalloc parameters overflow: size 0x%zx "
|
"ERROR: AddressSanitizer: pvalloc parameters overflow: size 0x%zx "
|
||||||
"rounded up to system page size 0x%zx cannot be represented in type "
|
"rounded up to system page size 0x%zx cannot be represented in type "
|
||||||
"size_t (thread T%d%s)\n",
|
"size_t (thread %s)\n",
|
||||||
size, GetPageSizeCached(), tid,
|
size, GetPageSizeCached(), AsanThreadIdAndName(tid).c_str());
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
stack->Print();
|
stack->Print();
|
||||||
PrintHintAllocatorCannotReturnNull();
|
PrintHintAllocatorCannotReturnNull();
|
||||||
|
@ -204,12 +195,11 @@ void ErrorPvallocOverflow::Print() {
|
||||||
|
|
||||||
void ErrorInvalidAllocationAlignment::Print() {
|
void ErrorInvalidAllocationAlignment::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: invalid allocation alignment: %zd, "
|
"ERROR: AddressSanitizer: invalid allocation alignment: %zd, "
|
||||||
"alignment must be a power of two (thread T%d%s)\n",
|
"alignment must be a power of two (thread %s)\n",
|
||||||
alignment, tid, ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
alignment, AsanThreadIdAndName(tid).c_str());
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
stack->Print();
|
stack->Print();
|
||||||
PrintHintAllocatorCannotReturnNull();
|
PrintHintAllocatorCannotReturnNull();
|
||||||
|
@ -218,19 +208,17 @@ void ErrorInvalidAllocationAlignment::Print() {
|
||||||
|
|
||||||
void ErrorInvalidAlignedAllocAlignment::Print() {
|
void ErrorInvalidAlignedAllocAlignment::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
#if SANITIZER_POSIX
|
#if SANITIZER_POSIX
|
||||||
Report("ERROR: AddressSanitizer: invalid alignment requested in "
|
Report("ERROR: AddressSanitizer: invalid alignment requested in "
|
||||||
"aligned_alloc: %zd, alignment must be a power of two and the "
|
"aligned_alloc: %zd, alignment must be a power of two and the "
|
||||||
"requested size 0x%zx must be a multiple of alignment "
|
"requested size 0x%zx must be a multiple of alignment "
|
||||||
"(thread T%d%s)\n", alignment, size, tid,
|
"(thread %s)\n", alignment, size, AsanThreadIdAndName(tid).c_str());
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
|
||||||
#else
|
#else
|
||||||
Report("ERROR: AddressSanitizer: invalid alignment requested in "
|
Report("ERROR: AddressSanitizer: invalid alignment requested in "
|
||||||
"aligned_alloc: %zd, the requested size 0x%zx must be a multiple of "
|
"aligned_alloc: %zd, the requested size 0x%zx must be a multiple of "
|
||||||
"alignment (thread T%d%s)\n", alignment, size, tid,
|
"alignment (thread %s)\n", alignment, size,
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
AsanThreadIdAndName(tid).c_str());
|
||||||
#endif
|
#endif
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
stack->Print();
|
stack->Print();
|
||||||
|
@ -240,14 +228,12 @@ void ErrorInvalidAlignedAllocAlignment::Print() {
|
||||||
|
|
||||||
void ErrorInvalidPosixMemalignAlignment::Print() {
|
void ErrorInvalidPosixMemalignAlignment::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: invalid alignment requested in posix_memalign: "
|
"ERROR: AddressSanitizer: invalid alignment requested in posix_memalign: "
|
||||||
"%zd, alignment must be a power of two and a multiple of sizeof(void*) "
|
"%zd, alignment must be a power of two and a multiple of sizeof(void*) "
|
||||||
"== %zd (thread T%d%s)\n",
|
"== %zd (thread %s)\n",
|
||||||
alignment, sizeof(void*), tid, // NOLINT
|
alignment, sizeof(void*), AsanThreadIdAndName(tid).c_str()); // NOLINT
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
stack->Print();
|
stack->Print();
|
||||||
PrintHintAllocatorCannotReturnNull();
|
PrintHintAllocatorCannotReturnNull();
|
||||||
|
@ -256,14 +242,12 @@ void ErrorInvalidPosixMemalignAlignment::Print() {
|
||||||
|
|
||||||
void ErrorAllocationSizeTooBig::Print() {
|
void ErrorAllocationSizeTooBig::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
char tname[128];
|
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: requested allocation size 0x%zx (0x%zx after "
|
"ERROR: AddressSanitizer: requested allocation size 0x%zx (0x%zx after "
|
||||||
"adjustments for alignment, red zones etc.) exceeds maximum supported "
|
"adjustments for alignment, red zones etc.) exceeds maximum supported "
|
||||||
"size of 0x%zx (thread T%d%s)\n",
|
"size of 0x%zx (thread %s)\n",
|
||||||
user_size, total_size, max_size, tid,
|
user_size, total_size, max_size, AsanThreadIdAndName(tid).c_str());
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)));
|
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
stack->Print();
|
stack->Print();
|
||||||
PrintHintAllocatorCannotReturnNull();
|
PrintHintAllocatorCannotReturnNull();
|
||||||
|
@ -272,7 +256,7 @@ void ErrorAllocationSizeTooBig::Print() {
|
||||||
|
|
||||||
void ErrorRssLimitExceeded::Print() {
|
void ErrorRssLimitExceeded::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: specified RSS limit exceeded, currently set to "
|
"ERROR: AddressSanitizer: specified RSS limit exceeded, currently set to "
|
||||||
"soft_rss_limit_mb=%zd\n", common_flags()->soft_rss_limit_mb);
|
"soft_rss_limit_mb=%zd\n", common_flags()->soft_rss_limit_mb);
|
||||||
|
@ -284,7 +268,7 @@ void ErrorRssLimitExceeded::Print() {
|
||||||
|
|
||||||
void ErrorOutOfMemory::Print() {
|
void ErrorOutOfMemory::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: allocator is out of memory trying to allocate "
|
"ERROR: AddressSanitizer: allocator is out of memory trying to allocate "
|
||||||
"0x%zx bytes\n", requested_size);
|
"0x%zx bytes\n", requested_size);
|
||||||
|
@ -298,7 +282,7 @@ void ErrorStringFunctionMemoryRangesOverlap::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
char bug_type[100];
|
char bug_type[100];
|
||||||
internal_snprintf(bug_type, sizeof(bug_type), "%s-param-overlap", function);
|
internal_snprintf(bug_type, sizeof(bug_type), "%s-param-overlap", function);
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report(
|
Report(
|
||||||
"ERROR: AddressSanitizer: %s: memory ranges [%p,%p) and [%p, %p) "
|
"ERROR: AddressSanitizer: %s: memory ranges [%p,%p) and [%p, %p) "
|
||||||
"overlap\n",
|
"overlap\n",
|
||||||
|
@ -315,7 +299,7 @@ void ErrorStringFunctionMemoryRangesOverlap::Print() {
|
||||||
|
|
||||||
void ErrorStringFunctionSizeOverflow::Print() {
|
void ErrorStringFunctionSizeOverflow::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report("ERROR: AddressSanitizer: %s: (size=%zd)\n",
|
Report("ERROR: AddressSanitizer: %s: (size=%zd)\n",
|
||||||
scariness.GetDescription(), size);
|
scariness.GetDescription(), size);
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
|
@ -343,7 +327,7 @@ void ErrorBadParamsToAnnotateContiguousContainer::Print() {
|
||||||
|
|
||||||
void ErrorODRViolation::Print() {
|
void ErrorODRViolation::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report("ERROR: AddressSanitizer: %s (%p):\n", scariness.GetDescription(),
|
Report("ERROR: AddressSanitizer: %s (%p):\n", scariness.GetDescription(),
|
||||||
global1.beg);
|
global1.beg);
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
|
@ -372,7 +356,7 @@ void ErrorODRViolation::Print() {
|
||||||
|
|
||||||
void ErrorInvalidPointerPair::Print() {
|
void ErrorInvalidPointerPair::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
Report("ERROR: AddressSanitizer: %s: %p %p\n", scariness.GetDescription(),
|
Report("ERROR: AddressSanitizer: %s: %p %p\n", scariness.GetDescription(),
|
||||||
addr1_description.Address(), addr2_description.Address());
|
addr1_description.Address(), addr2_description.Address());
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
|
@ -576,17 +560,15 @@ static void PrintShadowMemoryForAddress(uptr addr) {
|
||||||
|
|
||||||
void ErrorGeneric::Print() {
|
void ErrorGeneric::Print() {
|
||||||
Decorator d;
|
Decorator d;
|
||||||
Printf("%s", d.Warning());
|
Printf("%s", d.Error());
|
||||||
uptr addr = addr_description.Address();
|
uptr addr = addr_description.Address();
|
||||||
Report("ERROR: AddressSanitizer: %s on address %p at pc %p bp %p sp %p\n",
|
Report("ERROR: AddressSanitizer: %s on address %p at pc %p bp %p sp %p\n",
|
||||||
bug_descr, (void *)addr, pc, bp, sp);
|
bug_descr, (void *)addr, pc, bp, sp);
|
||||||
Printf("%s", d.Default());
|
Printf("%s", d.Default());
|
||||||
|
|
||||||
char tname[128];
|
Printf("%s%s of size %zu at %p thread %s%s\n", d.Access(),
|
||||||
Printf("%s%s of size %zu at %p thread T%d%s%s\n", d.Access(),
|
|
||||||
access_size ? (is_write ? "WRITE" : "READ") : "ACCESS", access_size,
|
access_size ? (is_write ? "WRITE" : "READ") : "ACCESS", access_size,
|
||||||
(void *)addr, tid,
|
(void *)addr, AsanThreadIdAndName(tid).c_str(), d.Default());
|
||||||
ThreadNameWithParenthesis(tid, tname, sizeof(tname)), d.Default());
|
|
||||||
|
|
||||||
scariness.Print();
|
scariness.Print();
|
||||||
GET_STACK_TRACE_FATAL(pc, bp);
|
GET_STACK_TRACE_FATAL(pc, bp);
|
||||||
|
|
Loading…
Reference in New Issue