summaryrefslogtreecommitdiff
path: root/libobjc
diff options
context:
space:
mode:
authorKai Tietz <ktietz@redhat.com>2013-07-04 11:03:31 +0200
committerKai Tietz <ktietz@gcc.gnu.org>2013-07-04 11:03:31 +0200
commit3e6769287412f9e8dc692324d8616b81ed256998 (patch)
treeac8dd899a58cfb447e5315bf55392d1486125a42 /libobjc
parentb727d9c4be45f0c0c405e41681632ea6badfe338 (diff)
downloadgcc-3e6769287412f9e8dc692324d8616b81ed256998.tar.gz
exception.c: Add check for SjLj to SEH blocks.
2013-07-04 Kai Tietz <ktietz@redhat.com> * exception.c: Add check for SjLj to SEH blocks. From-SVN: r200663
Diffstat (limited to 'libobjc')
-rw-r--r--libobjc/ChangeLog4
-rw-r--r--libobjc/exception.c8
2 files changed, 8 insertions, 4 deletions
diff --git a/libobjc/ChangeLog b/libobjc/ChangeLog
index 0c2512200f0..d26fd1d1261 100644
--- a/libobjc/ChangeLog
+++ b/libobjc/ChangeLog
@@ -1,3 +1,7 @@
+2013-07-04 Kai Tietz <ktietz@redhat.com>
+
+ * exception.c: Add check for SjLj to SEH blocks.
+
2013-02-03 Richard Sandiford <rdsandiford@googlemail.com>
Update copyright years.
diff --git a/libobjc/exception.c b/libobjc/exception.c
index 4b05611fedc..505086fedec 100644
--- a/libobjc/exception.c
+++ b/libobjc/exception.c
@@ -202,7 +202,7 @@ get_ttype_entry (struct lsda_header_info *info, _Unwind_Word i)
#ifdef SJLJ_EXCEPTIONS
#define PERSONALITY_FUNCTION __gnu_objc_personality_sj0
#define __builtin_eh_return_data_regno(x) x
-#elif defined(__SEH__)
+#elif defined(__SEH__) && !defined (__USING_SJLJ_EXCEPTIONS__)
#define PERSONALITY_FUNCTION __gnu_objc_personality_imp
#else
#define PERSONALITY_FUNCTION __gnu_objc_personality_v0
@@ -227,7 +227,7 @@ PERSONALITY_FUNCTION (_Unwind_State state,
#define CONTINUE_UNWINDING return _URC_CONTINUE_UNWIND
-#ifdef __SEH__
+#if defined (__SEH__) && !defined (__USING_SJLJ_EXCEPTIONS__)
static
#endif
_Unwind_Reason_Code
@@ -524,7 +524,7 @@ objc_exception_throw (id exception)
abort ();
}
-#ifdef __SEH__
+#if defined (__SEH__) && !defined (__USING_SJLJ_EXCEPTIONS__)
EXCEPTION_DISPOSITION
__gnu_objc_personality_seh0 (PEXCEPTION_RECORD ms_exc, void *this_frame,
PCONTEXT ms_orig_context,
@@ -533,4 +533,4 @@ __gnu_objc_personality_seh0 (PEXCEPTION_RECORD ms_exc, void *this_frame,
return _GCC_specific_handler (ms_exc, this_frame, ms_orig_context,
ms_disp, __gnu_objc_personality_imp);
}
-#endif /* SEH */
+#endif