Commit 9fc844b7 authored by rossberg@chromium.org's avatar rossberg@chromium.org

V8_Fatal now prints C++ stack trace in debug mode.

Currently only supported on Linux. When compiled with GCC, also demangles C++ identifier names.

Should make debugging those flaky crashes on buildbots easier... :)

R=mstarzinger@chromium.org,ulan@chromium.org
BUG=

Review URL: https://codereview.chromium.org/11577019

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@13222 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 1080d2aa
...@@ -62,6 +62,12 @@ endif ...@@ -62,6 +62,12 @@ endif
ifeq ($(verifyheap), on) ifeq ($(verifyheap), on)
GYPFLAGS += -Dv8_enable_verify_heap=1 GYPFLAGS += -Dv8_enable_verify_heap=1
endif endif
# backtrace=off
ifeq ($(backtrace), off)
GYPFLAGS += -Dv8_enable_backtrace=0
else
GYPFLAGS += -Dv8_enable_backtrace=1
endif
# snapshot=off # snapshot=off
ifeq ($(snapshot), off) ifeq ($(snapshot), off)
GYPFLAGS += -Dv8_use_snapshot='false' GYPFLAGS += -Dv8_use_snapshot='false'
......
...@@ -68,6 +68,8 @@ ...@@ -68,6 +68,8 @@
'v8_enable_debugger_support%': 1, 'v8_enable_debugger_support%': 1,
'v8_enable_backtrace%': 0,
'v8_enable_disassembler%': 0, 'v8_enable_disassembler%': 0,
'v8_enable_gdbjit%': 0, 'v8_enable_gdbjit%': 0,
...@@ -368,6 +370,10 @@ ...@@ -368,6 +370,10 @@
'cflags': [ '-Wall', '<(werror)', '-W', '-Wno-unused-parameter', 'cflags': [ '-Wall', '<(werror)', '-W', '-Wno-unused-parameter',
'-Wnon-virtual-dtor', '-Woverloaded-virtual' ], '-Wnon-virtual-dtor', '-Woverloaded-virtual' ],
}], }],
['OS=="linux" and v8_enable_backtrace==1', {
# Support for backtrace_symbols.
'ldflags': [ '-rdynamic' ],
}],
['OS=="android"', { ['OS=="android"', {
'variables': { 'variables': {
'android_full_debug%': 1, 'android_full_debug%': 1,
......
...@@ -100,7 +100,7 @@ ...@@ -100,7 +100,7 @@
[ 'OS=="linux"', { [ 'OS=="linux"', {
'cflags': [ '-ansi' ], 'cflags': [ '-ansi' ],
}], }],
[ 'visibility=="hidden"', { [ 'visibility=="hidden" and v8_enable_backtrace==0', {
'cflags': [ '-fvisibility=hidden' ], 'cflags': [ '-fvisibility=hidden' ],
}], }],
[ 'component=="shared_library"', { [ 'component=="shared_library"', {
......
...@@ -46,7 +46,8 @@ extern "C" void V8_Fatal(const char* file, int line, const char* format, ...) { ...@@ -46,7 +46,8 @@ extern "C" void V8_Fatal(const char* file, int line, const char* format, ...) {
va_start(arguments, format); va_start(arguments, format);
i::OS::VPrintError(format, arguments); i::OS::VPrintError(format, arguments);
va_end(arguments); va_end(arguments);
i::OS::PrintError("\n#\n\n"); i::OS::PrintError("\n#\n");
i::OS::DumpBacktrace();
} }
// First two times we may try to print a stack dump. // First two times we may try to print a stack dump.
if (fatal_error_handler_nesting_depth < 3) { if (fatal_error_handler_nesting_depth < 3) {
......
...@@ -812,7 +812,7 @@ static void PrintFrames(StringStream* accumulator, ...@@ -812,7 +812,7 @@ static void PrintFrames(StringStream* accumulator,
void Isolate::PrintStack(StringStream* accumulator) { void Isolate::PrintStack(StringStream* accumulator) {
if (!IsInitialized()) { if (!IsInitialized()) {
accumulator->Add( accumulator->Add(
"\n==== Stack trace is not available ==========================\n\n"); "\n==== JS stack trace is not available =======================\n\n");
accumulator->Add( accumulator->Add(
"\n==== Isolate for the thread is not initialized =============\n\n"); "\n==== Isolate for the thread is not initialized =============\n\n");
return; return;
...@@ -825,7 +825,7 @@ void Isolate::PrintStack(StringStream* accumulator) { ...@@ -825,7 +825,7 @@ void Isolate::PrintStack(StringStream* accumulator) {
if (c_entry_fp(thread_local_top()) == 0) return; if (c_entry_fp(thread_local_top()) == 0) return;
accumulator->Add( accumulator->Add(
"\n==== Stack trace ============================================\n\n"); "\n==== JS stack trace =========================================\n\n");
PrintFrames(accumulator, StackFrame::OVERVIEW); PrintFrames(accumulator, StackFrame::OVERVIEW);
accumulator->Add( accumulator->Add(
......
...@@ -38,6 +38,11 @@ ...@@ -38,6 +38,11 @@
#include <sys/types.h> #include <sys/types.h>
#include <stdlib.h> #include <stdlib.h>
#if defined(__GLIBC__)
#include <execinfo.h>
#include <cxxabi.h>
#endif
// Ubuntu Dapper requires memory pages to be marked as // Ubuntu Dapper requires memory pages to be marked as
// executable. Otherwise, OS raises an exception when executing code // executable. Otherwise, OS raises an exception when executing code
// in that page. // in that page.
...@@ -415,6 +420,37 @@ void OS::DebugBreak() { ...@@ -415,6 +420,37 @@ void OS::DebugBreak() {
} }
void OS::DumpBacktrace() {
#if defined(__GLIBC__)
void* trace[100];
int size = backtrace(trace, ARRAY_SIZE(trace));
char** symbols = backtrace_symbols(trace, size);
fprintf(stderr, "\n==== C stack trace ===============================\n\n");
if (size == 0) {
fprintf(stderr, "(empty)\n");
} else if (symbols == NULL) {
fprintf(stderr, "(no symbols)\n");
} else {
for (int i = 1; i < size; ++i) {
fprintf(stderr, "%2d: ", i);
char mangled[201];
if (sscanf(symbols[i], "%*[^(]%*[(]%200[^)+]", mangled) == 1) { // NOLINT
int status;
size_t length;
char* demangled = abi::__cxa_demangle(mangled, NULL, &length, &status);
fprintf(stderr, "%s\n", demangled ? demangled : mangled);
free(demangled);
} else {
fprintf(stderr, "??\n");
}
}
}
fflush(stderr);
free(symbols);
#endif
}
class PosixMemoryMappedFile : public OS::MemoryMappedFile { class PosixMemoryMappedFile : public OS::MemoryMappedFile {
public: public:
PosixMemoryMappedFile(FILE* file, void* memory, int size) PosixMemoryMappedFile(FILE* file, void* memory, int size)
......
...@@ -182,6 +182,11 @@ void OS::DebugBreak() { ...@@ -182,6 +182,11 @@ void OS::DebugBreak() {
} }
void OS::DumpBacktrace() {
// Currently unsupported.
}
class PosixMemoryMappedFile : public OS::MemoryMappedFile { class PosixMemoryMappedFile : public OS::MemoryMappedFile {
public: public:
PosixMemoryMappedFile(FILE* file, void* memory, int size) PosixMemoryMappedFile(FILE* file, void* memory, int size)
......
...@@ -277,6 +277,11 @@ void OS::DebugBreak() { ...@@ -277,6 +277,11 @@ void OS::DebugBreak() {
} }
void OS::DumpBacktrace() {
// Currently unsupported.
}
OS::MemoryMappedFile* OS::MemoryMappedFile::open(const char* name) { OS::MemoryMappedFile* OS::MemoryMappedFile::open(const char* name) {
UNIMPLEMENTED(); UNIMPLEMENTED();
return NULL; return NULL;
......
...@@ -215,6 +215,11 @@ void OS::DebugBreak() { ...@@ -215,6 +215,11 @@ void OS::DebugBreak() {
} }
void OS::DumpBacktrace() {
// Currently unsupported.
}
class PosixMemoryMappedFile : public OS::MemoryMappedFile { class PosixMemoryMappedFile : public OS::MemoryMappedFile {
public: public:
PosixMemoryMappedFile(FILE* file, void* memory, int size) PosixMemoryMappedFile(FILE* file, void* memory, int size)
......
...@@ -202,6 +202,11 @@ void OS::DebugBreak() { ...@@ -202,6 +202,11 @@ void OS::DebugBreak() {
} }
void OS::DumpBacktrace() {
// Currently unsupported.
}
class PosixMemoryMappedFile : public OS::MemoryMappedFile { class PosixMemoryMappedFile : public OS::MemoryMappedFile {
public: public:
PosixMemoryMappedFile(FILE* file, void* memory, int size) PosixMemoryMappedFile(FILE* file, void* memory, int size)
......
...@@ -987,6 +987,11 @@ void OS::DebugBreak() { ...@@ -987,6 +987,11 @@ void OS::DebugBreak() {
} }
void OS::DumpBacktrace() {
// Currently unsupported.
}
class Win32MemoryMappedFile : public OS::MemoryMappedFile { class Win32MemoryMappedFile : public OS::MemoryMappedFile {
public: public:
Win32MemoryMappedFile(HANDLE file, Win32MemoryMappedFile(HANDLE file,
......
...@@ -245,6 +245,9 @@ class OS { ...@@ -245,6 +245,9 @@ class OS {
// Debug break. // Debug break.
static void DebugBreak(); static void DebugBreak();
// Dump C++ current stack trace (only functional on Linux).
static void DumpBacktrace();
// Walk the stack. // Walk the stack.
static const int kStackWalkError = -1; static const int kStackWalkError = -1;
static const int kStackWalkMaxNameLen = 256; static const int kStackWalkMaxNameLen = 256;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment