Index: runtime/vm/signal_handler_macos.cc |
diff --git a/runtime/vm/signal_handler_macos.cc b/runtime/vm/signal_handler_macos.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..f0e5b15036b57650cb7bb6a56f3ba5d113ebfac5 |
--- /dev/null |
+++ b/runtime/vm/signal_handler_macos.cc |
@@ -0,0 +1,96 @@ |
+// Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
+// for details. All rights reserved. Use of this source code is governed by a |
+// BSD-style license that can be found in the LICENSE file. |
+ |
+#include "vm/globals.h" |
+#include "vm/simulator.h" |
+#include "vm/signal_handler.h" |
+#if defined(TARGET_OS_MACOS) |
+ |
+namespace dart { |
+ |
+uintptr_t SignalHandler::GetProgramCounter(const mcontext_t& mcontext) { |
+ uintptr_t pc = 0; |
+ |
+#if defined(TARGET_ARCH_IA32) |
+ pc = static_cast<uintptr_t>(mcontext->__ss.__eip); |
+#elif defined(TARGET_ARCH_X64) |
+ pc = static_cast<uintptr_t>(mcontext->__ss.__rip); |
+#elif defined(TARGET_ARCH_MIPS) && defined(USING_SIMULATOR) |
+ pc = static_cast<uintptr_t>(mcontext->__ss.__eip); |
+#elif defined(TARGET_ARCH_ARM) && defined(USING_SIMULATOR) |
+ pc = static_cast<uintptr_t>(mcontext->__ss.__eip); |
+#else |
+ UNIMPLEMENTED(); |
+#endif // TARGET_ARCH_... |
+ |
+ return pc; |
+} |
+ |
+ |
+uintptr_t SignalHandler::GetFramePointer(const mcontext_t& mcontext) { |
+ uintptr_t fp = 0; |
+ |
+#if defined(TARGET_ARCH_IA32) |
+ fp = static_cast<uintptr_t>(mcontext->__ss.__ebp); |
+#elif defined(TARGET_ARCH_X64) |
+ fp = static_cast<uintptr_t>(mcontext->__ss.__rbp); |
+#elif defined(TARGET_ARCH_MIPS) && defined(USING_SIMULATOR) |
+ fp = static_cast<uintptr_t>(mcontext->__ss.__ebp); |
+#elif defined(TARGET_ARCH_ARM) && defined(USING_SIMULATOR) |
+ fp = static_cast<uintptr_t>(mcontext->__ss.__ebp); |
+#else |
+ UNIMPLEMENTED(); |
+#endif // TARGET_ARCH_... |
+ |
+ return fp; |
+} |
+ |
+ |
+uintptr_t SignalHandler::GetStackPointer(const mcontext_t& mcontext) { |
+ uintptr_t sp = 0; |
+ |
+#if defined(TARGET_ARCH_IA32) |
+ sp = static_cast<uintptr_t>(mcontext->__ss.__esp); |
+#elif defined(TARGET_ARCH_X64) |
+ sp = static_cast<uintptr_t>(mcontext->__ss.__rsp); |
+#elif defined(TARGET_ARCH_MIPS) && defined(USING_SIMULATOR) |
+ sp = static_cast<uintptr_t>(mcontext->__ss.__esp); |
+#elif defined(TARGET_ARCH_ARM) && defined(USING_SIMULATOR) |
+ sp = static_cast<uintptr_t>(mcontext->__ss.__esp); |
+#else |
+ UNIMPLEMENTED(); |
+#endif // TARGET_ARCH_... |
+ |
+ return sp; |
+} |
+ |
+ |
+void SignalHandler::Install(SignalAction action) { |
+ struct sigaction act; |
+ act.sa_handler = NULL; |
+ act.sa_sigaction = action; |
+ sigemptyset(&act.sa_mask); |
+ act.sa_flags = SA_RESTART | SA_SIGINFO; |
+ // TODO(johnmccutchan): Do we care about restoring the signal handler? |
+ struct sigaction old_act; |
+ int r = sigaction(SIGPROF, &act, &old_act); |
+ ASSERT(r == 0); |
+} |
+ |
+ |
+ScopedSignalBlocker::ScopedSignalBlocker() { |
+ sigset_t set; |
+ sigemptyset(&set); |
+ sigaddset(&set, SIGPROF); |
+ pthread_sigmask(SIG_SETMASK, &set, &old_); |
+} |
+ |
+ |
+ScopedSignalBlocker::~ScopedSignalBlocker() { |
+ pthread_sigmask(SIG_SETMASK, &old_, NULL); |
+} |
+ |
+} // namespace dart |
+ |
+#endif // defined(TARGET_OS_MACOS) |