Index: src/client/linux/dump_writer_common/seccomp_unwinder.cc |
diff --git a/src/client/linux/dump_writer_common/seccomp_unwinder.cc b/src/client/linux/dump_writer_common/seccomp_unwinder.cc |
deleted file mode 100644 |
index e9d1ec7801f6bb044401eab2d1fd2761122caca3..0000000000000000000000000000000000000000 |
--- a/src/client/linux/dump_writer_common/seccomp_unwinder.cc |
+++ /dev/null |
@@ -1,154 +0,0 @@ |
-// Copyright (c) 2014, Google Inc. |
-// All rights reserved. |
-// |
-// Redistribution and use in source and binary forms, with or without |
-// modification, are permitted provided that the following conditions are |
-// met: |
-// |
-// * Redistributions of source code must retain the above copyright |
-// notice, this list of conditions and the following disclaimer. |
-// * Redistributions in binary form must reproduce the above |
-// copyright notice, this list of conditions and the following disclaimer |
-// in the documentation and/or other materials provided with the |
-// distribution. |
-// * Neither the name of Google Inc. nor the names of its |
-// contributors may be used to endorse or promote products derived from |
-// this software without specific prior written permission. |
-// |
-// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
-// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
-// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
-// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
-// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
-// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
-// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
-// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
-// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
-// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
-// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
- |
-#include "client/linux/dump_writer_common/seccomp_unwinder.h" |
- |
-#include <string.h> |
- |
-#include "google_breakpad/common/minidump_format.h" |
-#include "common/linux/linux_libc_support.h" |
- |
-namespace google_breakpad { |
- |
-void SeccompUnwinder::PopSeccompStackFrame(RawContextCPU* cpu, |
- const MDRawThread& thread, |
- uint8_t* stack_copy) { |
-#if defined(__x86_64) |
- uint64_t bp = cpu->rbp; |
- uint64_t top = thread.stack.start_of_memory_range; |
- for (int i = 4; i--; ) { |
- if (bp < top || |
- bp > thread.stack.start_of_memory_range + |
- thread.stack.memory.data_size - sizeof(bp) || |
- bp & 1) { |
- break; |
- } |
- uint64_t old_top = top; |
- top = bp; |
- uint8_t* bp_addr = stack_copy + bp - thread.stack.start_of_memory_range; |
- my_memcpy(&bp, bp_addr, sizeof(bp)); |
- if (bp == 0xDEADBEEFDEADBEEFull) { |
- struct { |
- uint64_t r15; |
- uint64_t r14; |
- uint64_t r13; |
- uint64_t r12; |
- uint64_t r11; |
- uint64_t r10; |
- uint64_t r9; |
- uint64_t r8; |
- uint64_t rdi; |
- uint64_t rsi; |
- uint64_t rdx; |
- uint64_t rcx; |
- uint64_t rbx; |
- uint64_t deadbeef; |
- uint64_t rbp; |
- uint64_t fakeret; |
- uint64_t ret; |
- /* char redzone[128]; */ |
- } seccomp_stackframe; |
- if (top - offsetof(__typeof__(seccomp_stackframe), deadbeef) < old_top || |
- top - offsetof(__typeof__(seccomp_stackframe), deadbeef) + |
- sizeof(seccomp_stackframe) > |
- thread.stack.start_of_memory_range+thread.stack.memory.data_size) { |
- break; |
- } |
- my_memcpy(&seccomp_stackframe, |
- bp_addr - offsetof(__typeof__(seccomp_stackframe), deadbeef), |
- sizeof(seccomp_stackframe)); |
- cpu->rbx = seccomp_stackframe.rbx; |
- cpu->rcx = seccomp_stackframe.rcx; |
- cpu->rdx = seccomp_stackframe.rdx; |
- cpu->rsi = seccomp_stackframe.rsi; |
- cpu->rdi = seccomp_stackframe.rdi; |
- cpu->rbp = seccomp_stackframe.rbp; |
- cpu->rsp = top + 4*sizeof(uint64_t) + 128; |
- cpu->r8 = seccomp_stackframe.r8; |
- cpu->r9 = seccomp_stackframe.r9; |
- cpu->r10 = seccomp_stackframe.r10; |
- cpu->r11 = seccomp_stackframe.r11; |
- cpu->r12 = seccomp_stackframe.r12; |
- cpu->r13 = seccomp_stackframe.r13; |
- cpu->r14 = seccomp_stackframe.r14; |
- cpu->r15 = seccomp_stackframe.r15; |
- cpu->rip = seccomp_stackframe.fakeret; |
- return; |
- } |
- } |
-#elif defined(__i386__) |
- uint32_t bp = cpu->ebp; |
- uint32_t top = thread.stack.start_of_memory_range; |
- for (int i = 4; i--; ) { |
- if (bp < top || |
- bp > thread.stack.start_of_memory_range + |
- thread.stack.memory.data_size - sizeof(bp) || |
- bp & 1) { |
- break; |
- } |
- uint32_t old_top = top; |
- top = bp; |
- uint8_t* bp_addr = stack_copy + bp - thread.stack.start_of_memory_range; |
- my_memcpy(&bp, bp_addr, sizeof(bp)); |
- if (bp == 0xDEADBEEFu) { |
- struct { |
- uint32_t edi; |
- uint32_t esi; |
- uint32_t edx; |
- uint32_t ecx; |
- uint32_t ebx; |
- uint32_t deadbeef; |
- uint32_t ebp; |
- uint32_t fakeret; |
- uint32_t ret; |
- } seccomp_stackframe; |
- if (top - offsetof(__typeof__(seccomp_stackframe), deadbeef) < old_top || |
- top - offsetof(__typeof__(seccomp_stackframe), deadbeef) + |
- sizeof(seccomp_stackframe) > |
- thread.stack.start_of_memory_range+thread.stack.memory.data_size) { |
- break; |
- } |
- my_memcpy(&seccomp_stackframe, |
- bp_addr - offsetof(__typeof__(seccomp_stackframe), deadbeef), |
- sizeof(seccomp_stackframe)); |
- cpu->ebx = seccomp_stackframe.ebx; |
- cpu->ecx = seccomp_stackframe.ecx; |
- cpu->edx = seccomp_stackframe.edx; |
- cpu->esi = seccomp_stackframe.esi; |
- cpu->edi = seccomp_stackframe.edi; |
- cpu->ebp = seccomp_stackframe.ebp; |
- cpu->esp = top + 4*sizeof(void*); |
- cpu->eip = seccomp_stackframe.fakeret; |
- return; |
- } |
- } |
-#endif |
-} |
- |
-} // namespace google_breakpad |