summaryrefslogtreecommitdiff
path: root/src/cxa_exception.cpp
diff options
context:
space:
mode:
authorNico Weber <nicolasweber@gmx.de>2014-06-25 23:52:07 +0000
committerNico Weber <nicolasweber@gmx.de>2014-06-25 23:52:07 +0000
commitd6e233687f0e2a20e77f864f96503d1b73f9d7de (patch)
tree7ea08e709e1064fcfc25425c2a67338a4a115d25 /src/cxa_exception.cpp
parentb9e4316e264c0094d0843bd8f4e9bc0fcd14ba91 (diff)
Update libc++abi to use the ARM EHABI unwinder from its libunwind.
git-svn-id: https://llvm.org/svn/llvm-project/libcxxabi/trunk@211745 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'src/cxa_exception.cpp')
-rw-r--r--src/cxa_exception.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/cxa_exception.cpp b/src/cxa_exception.cpp
index 13c060c..d5bc74a 100644
--- a/src/cxa_exception.cpp
+++ b/src/cxa_exception.cpp
@@ -447,8 +447,17 @@ For a foreign exception:
*/
void __cxa_end_catch()
{
- static_assert(sizeof(__cxa_exception) == sizeof(__cxa_dependent_exception),
- "sizeof(__cxa_exception) must be equal to sizeof(__cxa_dependent_exception)");
+ static_assert(sizeof(__cxa_exception) == sizeof(__cxa_dependent_exception),
+ "sizeof(__cxa_exception) must be equal to "
+ "sizeof(__cxa_dependent_exception)");
+ static_assert(offsetof(__cxa_exception, referenceCount) ==
+ offsetof(__cxa_dependent_exception, primaryException),
+ "the layout of __cxa_exception must match the layout of "
+ "__cxa_dependent_exception");
+ static_assert(offsetof(__cxa_exception, handlerCount) ==
+ offsetof(__cxa_dependent_exception, handlerCount),
+ "the layout of __cxa_exception must match the layout of "
+ "__cxa_dependent_exception");
__cxa_eh_globals* globals = __cxa_get_globals_fast(); // __cxa_get_globals called in __cxa_begin_catch
__cxa_exception* exception_header = globals->caughtExceptions;
// If we've rethrown a foreign exception, then globals->caughtExceptions