diff options
author | Christopher Ferris <cferris@google.com> | 2014-05-23 22:35:49 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2014-05-23 22:35:49 +0000 |
commit | 012090e57b697133ad6f7d989e103d71302749f8 (patch) | |
tree | 5c1f4ce30110d4693f578e3c83b462ddeb529898 | |
parent | 7aa8cdfb317dcb7efb7127b070526df09da05377 (diff) | |
parent | a0962b687a20dace14b5b2e12d96141a51140cab (diff) | |
download | system_core-012090e57b697133ad6f7d989e103d71302749f8.zip system_core-012090e57b697133ad6f7d989e103d71302749f8.tar.gz system_core-012090e57b697133ad6f7d989e103d71302749f8.tar.bz2 |
am a0962b68: am d917d64f: Merge "Only copy mcontext data from sigcontext."
* commit 'a0962b687a20dace14b5b2e12d96141a51140cab':
Only copy mcontext data from sigcontext.
-rw-r--r-- | libbacktrace/BacktraceThread.cpp | 8 | ||||
-rw-r--r-- | libbacktrace/BacktraceThread.h | 6 |
2 files changed, 9 insertions, 5 deletions
diff --git a/libbacktrace/BacktraceThread.cpp b/libbacktrace/BacktraceThread.cpp index 018d51f..b47cd2a 100644 --- a/libbacktrace/BacktraceThread.cpp +++ b/libbacktrace/BacktraceThread.cpp @@ -117,6 +117,12 @@ void ThreadEntry::Wake() { futex(&futex_, FUTEX_WAKE, INT_MAX, NULL, NULL, 0); } +void ThreadEntry::CopyUcontextFromSigcontext(void* sigcontext) { + ucontext_t* ucontext = reinterpret_cast<ucontext_t*>(sigcontext); + // The only thing the unwinder cares about is the mcontext data. + memcpy(&ucontext_.uc_mcontext, &ucontext->uc_mcontext, sizeof(ucontext->uc_mcontext)); +} + //------------------------------------------------------------------------- // BacktraceThread functions. //------------------------------------------------------------------------- @@ -129,7 +135,7 @@ static void SignalHandler(int, siginfo_t*, void* sigcontext) { return; } - entry->CopyUcontext(reinterpret_cast<ucontext_t*>(sigcontext)); + entry->CopyUcontextFromSigcontext(sigcontext); // Indicate the ucontext is now valid. entry->Wake(); diff --git a/libbacktrace/BacktraceThread.h b/libbacktrace/BacktraceThread.h index a75a807..ff3e9f3 100644 --- a/libbacktrace/BacktraceThread.h +++ b/libbacktrace/BacktraceThread.h @@ -40,14 +40,12 @@ public: static void Remove(ThreadEntry* entry); - inline void CopyUcontext(ucontext_t* ucontext) { - memcpy(&ucontext_, ucontext, sizeof(ucontext_)); - } - void Wake(); void Wait(int); + void CopyUcontextFromSigcontext(void*); + inline void Lock() { pthread_mutex_lock(&mutex_); // Reset the futex value in case of multiple unwinds of the same thread. |