Commit c5b8a2c9 authored by erik.corry@gmail.com's avatar erik.corry@gmail.com

Fixes to Solaris build. signbit and StackWalker. This is a commit for

ry (coldredlemur@gmail.com).  See http://codereview.chromium.org/2092007


git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@4677 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 19d98493
...@@ -35,7 +35,8 @@ ...@@ -35,7 +35,8 @@
#include <sys/stack.h> // for stack alignment #include <sys/stack.h> // for stack alignment
#include <unistd.h> // getpagesize(), usleep() #include <unistd.h> // getpagesize(), usleep()
#include <sys/mman.h> // mmap() #include <sys/mman.h> // mmap()
#include <execinfo.h> // backtrace(), backtrace_symbols() #include <ucontext.h> // walkstack(), getcontext()
#include <dlfcn.h> // dladdr
#include <pthread.h> #include <pthread.h>
#include <sched.h> // for sched_yield #include <sched.h> // for sched_yield
#include <semaphore.h> #include <semaphore.h>
...@@ -53,6 +54,24 @@ ...@@ -53,6 +54,24 @@
#include "platform.h" #include "platform.h"
// It seems there is a bug in some Solaris distributions (experienced in
// SunOS 5.10 Generic_141445-09) which make it difficult or impossible to
// access signbit() despite the availability of other C99 math functions.
#ifndef signbit
// Test sign - usually defined in math.h
int signbit(double x) {
// We need to take care of the special case of both positive and negative
// versions of zero.
if (x == 0) {
return fpclass(x) & FP_NZERO;
} else {
// This won't detect negative NaN but that should be okay since we don't
// assume that behavior.
return x < 0;
}
}
#endif // signbit
namespace v8 { namespace v8 {
namespace internal { namespace internal {
...@@ -231,31 +250,55 @@ void OS::LogSharedLibraryAddresses() { ...@@ -231,31 +250,55 @@ void OS::LogSharedLibraryAddresses() {
} }
int OS::StackWalk(Vector<OS::StackFrame> frames) { struct StackWalker {
int frames_size = frames.length(); Vector<OS::StackFrame>& frames;
ScopedVector<void*> addresses(frames_size); int index;
};
int frames_count = backtrace(addresses.start(), frames_size);
char** symbols = backtrace_symbols(addresses.start(), frames_count); static int StackWalkCallback(uintptr_t pc, int signo, void* data) {
if (symbols == NULL) { struct StackWalker* walker = static_cast<struct StackWalker*>(data);
return kStackWalkError; Dl_info info;
}
int i = walker->index;
walker->frames[i].address = reinterpret_cast<void*>(pc);
for (int i = 0; i < frames_count; i++) { // Make sure line termination is in place.
frames[i].address = addresses[i]; walker->frames[i].text[OS::kStackWalkMaxTextLen - 1] = '\0';
// Format a text representation of the frame based on the information
// available. Vector<char> text = MutableCStrVector(walker->frames[i].text,
SNPrintF(MutableCStrVector(frames[i].text, kStackWalkMaxTextLen), OS::kStackWalkMaxTextLen);
"%s",
symbols[i]); if (dladdr(reinterpret_cast<void*>(pc), &info) == 0) {
// Make sure line termination is in place. OS::SNPrintF(text, "[0x%p]", pc);
frames[i].text[kStackWalkMaxTextLen - 1] = '\0'; } else if ((info.dli_fname != NULL && info.dli_sname != NULL)) {
// We have symbol info.
OS::SNPrintF(text, "%s'%s+0x%x", info.dli_fname, info.dli_sname, pc);
} else {
// No local symbol info.
OS::SNPrintF(text,
"%s'0x%p [0x%p]",
info.dli_fname,
pc - reinterpret_cast<uintptr_t>(info.dli_fbase),
pc);
} }
walker->index++;
return 0;
}
free(symbols);
return frames_count; int OS::StackWalk(Vector<OS::StackFrame> frames) {
ucontext_t ctx;
struct StackWalker walker = { frames, 0 };
if (getcontext(&ctx) < 0) return kStackWalkError;
if (!walkcontext(&ctx, StackWalkCallback, &walker)) {
return kStackWalkError;
}
return walker.index;
} }
......
...@@ -83,6 +83,14 @@ int random(); ...@@ -83,6 +83,14 @@ int random();
#endif // WIN32 #endif // WIN32
#ifdef __sun
# ifndef signbit
int signbit(double x);
# endif
#endif
// GCC specific stuff // GCC specific stuff
#ifdef __GNUC__ #ifdef __GNUC__
......
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