Index: third_party/libc++abi/src/Unwind/Unwind_AppleExtras.cpp |
=================================================================== |
--- third_party/libc++abi/src/Unwind/Unwind_AppleExtras.cpp (revision 0) |
+++ third_party/libc++abi/src/Unwind/Unwind_AppleExtras.cpp (revision 0) |
@@ -0,0 +1,205 @@ |
+//===--------------------- Unwind_AppleExtras.cpp -------------------------===// |
+// |
+// The LLVM Compiler Infrastructure |
+// |
+// This file is dual licensed under the MIT and the University of Illinois Open |
+// Source Licenses. See LICENSE.TXT for details. |
+// |
+// |
+//===----------------------------------------------------------------------===// |
+ |
+#include "config.h" |
+#include "DwarfParser.hpp" |
+#include "unwind_ext.h" |
+ |
+ |
+// private keymgr stuff |
+#define KEYMGR_GCC3_DW2_OBJ_LIST 302 |
+extern "C" { |
+ extern void _keymgr_set_and_unlock_processwide_ptr(int key, void *ptr); |
+ extern void *_keymgr_get_and_lock_processwide_ptr(int key); |
+} |
+ |
+// undocumented libgcc "struct object" |
+struct libgcc_object { |
+ void *start; |
+ void *unused1; |
+ void *unused2; |
+ void *fde; |
+ unsigned long encoding; |
+ void *fde_end; |
+ libgcc_object *next; |
+}; |
+ |
+// undocumented libgcc "struct km_object_info" referenced by |
+// KEYMGR_GCC3_DW2_OBJ_LIST |
+struct libgcc_object_info { |
+ libgcc_object *seen_objects; |
+ libgcc_object *unseen_objects; |
+ unsigned spare[2]; |
+}; |
+ |
+ |
+// static linker symbols to prevent wrong two level namespace for _Unwind symbols |
+#if __arm__ |
+ #define NOT_HERE_BEFORE_5_0(sym) \ |
+ extern const char sym##_tmp30 __asm("$ld$hide$os3.0$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp30 = 0; \ |
+ extern const char sym##_tmp31 __asm("$ld$hide$os3.1$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp31 = 0; \ |
+ extern const char sym##_tmp32 __asm("$ld$hide$os3.2$_" #sym );\ |
+ __attribute__((visibility("default"))) const char sym##_tmp32 = 0; \ |
+ extern const char sym##_tmp40 __asm("$ld$hide$os4.0$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp40 = 0; \ |
+ extern const char sym##_tmp41 __asm("$ld$hide$os4.1$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp41 = 0; \ |
+ extern const char sym##_tmp42 __asm("$ld$hide$os4.2$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp42 = 0; \ |
+ extern const char sym##_tmp43 __asm("$ld$hide$os4.3$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp43 = 0; |
+#elif __arm64__ |
+ #define NOT_HERE_BEFORE_10_6(sym) |
+ #define NEVER_HERE(sym) |
+#else |
+ #define NOT_HERE_BEFORE_10_6(sym) \ |
+ extern const char sym##_tmp4 __asm("$ld$hide$os10.4$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp4 = 0; \ |
+ extern const char sym##_tmp5 __asm("$ld$hide$os10.5$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp5 = 0; |
+ #define NEVER_HERE(sym) \ |
+ extern const char sym##_tmp4 __asm("$ld$hide$os10.4$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp4 = 0; \ |
+ extern const char sym##_tmp5 __asm("$ld$hide$os10.5$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp5 = 0; \ |
+ extern const char sym##_tmp6 __asm("$ld$hide$os10.6$_" #sym ); \ |
+ __attribute__((visibility("default"))) const char sym##_tmp6 = 0; |
+#endif |
+ |
+ |
+#if _LIBUNWIND_BUILD_ZERO_COST_APIS |
+ |
+// |
+// symbols in libSystem.dylib in 10.6 and later, but are in libgcc_s.dylib in |
+// earlier versions |
+// |
+NOT_HERE_BEFORE_10_6(_Unwind_DeleteException) |
+NOT_HERE_BEFORE_10_6(_Unwind_Find_FDE) |
+NOT_HERE_BEFORE_10_6(_Unwind_ForcedUnwind) |
+NOT_HERE_BEFORE_10_6(_Unwind_GetGR) |
+NOT_HERE_BEFORE_10_6(_Unwind_GetIP) |
+NOT_HERE_BEFORE_10_6(_Unwind_GetLanguageSpecificData) |
+NOT_HERE_BEFORE_10_6(_Unwind_GetRegionStart) |
+NOT_HERE_BEFORE_10_6(_Unwind_RaiseException) |
+NOT_HERE_BEFORE_10_6(_Unwind_Resume) |
+NOT_HERE_BEFORE_10_6(_Unwind_SetGR) |
+NOT_HERE_BEFORE_10_6(_Unwind_SetIP) |
+NOT_HERE_BEFORE_10_6(_Unwind_Backtrace) |
+NOT_HERE_BEFORE_10_6(_Unwind_FindEnclosingFunction) |
+NOT_HERE_BEFORE_10_6(_Unwind_GetCFA) |
+NOT_HERE_BEFORE_10_6(_Unwind_GetDataRelBase) |
+NOT_HERE_BEFORE_10_6(_Unwind_GetTextRelBase) |
+NOT_HERE_BEFORE_10_6(_Unwind_Resume_or_Rethrow) |
+NOT_HERE_BEFORE_10_6(_Unwind_GetIPInfo) |
+NOT_HERE_BEFORE_10_6(__register_frame) |
+NOT_HERE_BEFORE_10_6(__deregister_frame) |
+ |
+// |
+// symbols in libSystem.dylib for compatibility, but we don't want any new code |
+// using them |
+// |
+NEVER_HERE(__register_frame_info_bases) |
+NEVER_HERE(__register_frame_info) |
+NEVER_HERE(__register_frame_info_table_bases) |
+NEVER_HERE(__register_frame_info_table) |
+NEVER_HERE(__register_frame_table) |
+NEVER_HERE(__deregister_frame_info) |
+NEVER_HERE(__deregister_frame_info_bases) |
+ |
+#endif // _LIBUNWIND_BUILD_ZERO_COST_APIS |
+ |
+ |
+ |
+ |
+#if _LIBUNWIND_BUILD_SJLJ_APIS |
+// |
+// symbols in libSystem.dylib in iOS 5.0 and later, but are in libgcc_s.dylib in |
+// earlier versions |
+// |
+NOT_HERE_BEFORE_5_0(_Unwind_GetLanguageSpecificData) |
+NOT_HERE_BEFORE_5_0(_Unwind_GetRegionStart) |
+NOT_HERE_BEFORE_5_0(_Unwind_GetIP) |
+NOT_HERE_BEFORE_5_0(_Unwind_SetGR) |
+NOT_HERE_BEFORE_5_0(_Unwind_SetIP) |
+NOT_HERE_BEFORE_5_0(_Unwind_DeleteException) |
+NOT_HERE_BEFORE_5_0(_Unwind_SjLj_Register) |
+NOT_HERE_BEFORE_5_0(_Unwind_GetGR) |
+NOT_HERE_BEFORE_5_0(_Unwind_GetIPInfo) |
+NOT_HERE_BEFORE_5_0(_Unwind_GetCFA) |
+NOT_HERE_BEFORE_5_0(_Unwind_SjLj_Resume) |
+NOT_HERE_BEFORE_5_0(_Unwind_SjLj_RaiseException) |
+NOT_HERE_BEFORE_5_0(_Unwind_SjLj_Resume_or_Rethrow) |
+NOT_HERE_BEFORE_5_0(_Unwind_SjLj_Unregister) |
+ |
+#endif // _LIBUNWIND_BUILD_SJLJ_APIS |
+ |
+ |
+namespace libunwind { |
+ |
+_LIBUNWIND_HIDDEN |
+bool checkKeyMgrRegisteredFDEs(uintptr_t pc, void *&fde) { |
+#if __MAC_OS_X_VERSION_MIN_REQUIRED |
+ // lastly check for old style keymgr registration of dynamically generated |
+ // FDEs acquire exclusive access to libgcc_object_info |
+ libgcc_object_info *head = (libgcc_object_info *) |
+ _keymgr_get_and_lock_processwide_ptr(KEYMGR_GCC3_DW2_OBJ_LIST); |
+ if (head != NULL) { |
+ // look at each FDE in keymgr |
+ for (libgcc_object *ob = head->unseen_objects; ob != NULL; ob = ob->next) { |
+ CFI_Parser<LocalAddressSpace>::FDE_Info fdeInfo; |
+ CFI_Parser<LocalAddressSpace>::CIE_Info cieInfo; |
+ const char *msg = CFI_Parser<LocalAddressSpace>::decodeFDE( |
+ LocalAddressSpace::sThisAddressSpace, |
+ (uintptr_t)ob->fde, &fdeInfo, &cieInfo); |
+ if (msg == NULL) { |
+ // Check if this FDE is for a function that includes the pc |
+ if ((fdeInfo.pcStart <= pc) && (pc < fdeInfo.pcEnd)) { |
+ fde = (void*)fdeInfo.pcStart; |
+ _keymgr_set_and_unlock_processwide_ptr(KEYMGR_GCC3_DW2_OBJ_LIST, |
+ head); |
+ return true; |
+ } |
+ } |
+ } |
+ } |
+ // release libgcc_object_info |
+ _keymgr_set_and_unlock_processwide_ptr(KEYMGR_GCC3_DW2_OBJ_LIST, head); |
+#else |
+ (void)pc; |
+ (void)fde; |
+#endif |
+ return false; |
+} |
+ |
+} |
+ |
+ |
+#if !FOR_DYLD && _LIBUNWIND_BUILD_SJLJ_APIS |
+ |
+#include <System/pthread_machdep.h> |
+ |
+// Accessors to get get/set linked list of frames for sjlj based execeptions. |
+_LIBUNWIND_HIDDEN |
+struct _Unwind_FunctionContext *__Unwind_SjLj_GetTopOfFunctionStack() { |
+ return (struct _Unwind_FunctionContext *) |
+ _pthread_getspecific_direct(__PTK_LIBC_DYLD_Unwind_SjLj_Key); |
+} |
+ |
+_LIBUNWIND_HIDDEN |
+void __Unwind_SjLj_SetTopOfFunctionStack(struct _Unwind_FunctionContext *fc) { |
+ _pthread_setspecific_direct(__PTK_LIBC_DYLD_Unwind_SjLj_Key, fc); |
+} |
+#endif |
+ |
+ |
+ |
+ |
Property changes on: third_party/libc++abi/src/Unwind/Unwind_AppleExtras.cpp |
___________________________________________________________________ |
Added: svn:eol-style |
+ LF |