almost all recent changes to libc++ and libcxxrt. MFC r256642: Since C++ typeinfo objects are currently not guaranteed to be merged at runtime by the dynamic linker, check for their equality in libcxxrt by not only comparing the typeinfo's name pointers, but also comparing the full names, if necessary. (This is similar to what GNU libstdc++ does in its default configuration.) The 'deep' check can be turned off again by defining LIBCXXRT_MERGED_TYPEINFO, and recompiling libcxxrt. Reviewed by: theraven MFC r270522 (by rdivacky): The standard we compile libc++ with is called c++11 not c++0x. MFC r273066 (by bapt): Import patch from libc++ r197313 which allows using libc++ headers with gcc Differential Revision: https://reviews.freebsd.org/D942 Reviewed by: imp MFC r273381 (by bapt): Add support for __cxa_throw_bad_array_new_length in libcxxrt It is required for use with newer g++49 Differential Revision: https://reviews.freebsd.org/D982 Reviewed by: theraven Approved by: theraven MFC r273382 (by bapt): Fix build by marking the new functions as weak This is a temporary fix MFC r273407 (by bapt): When using an external gcc 4.8+ and not building libstdc++ then create in the objectdir a fake libstdc++.so and libstdc++.a which is a symlink on libc++ that allow g++ to satisfy its links dependencies in the least hackish way. Please note that this hacky libstds++ never get installed on the final system Reviewed by: imp MFC r273434 (by bapt): Do not define bad_array_new_length::bad_array_new_length in libc++ anymore when used in combinaison with libcxxrt since it is now defined there already. This fixes building world MFC r276417: Import libcxxrt master 00bc29eb6513624824a6d7db2ebc768a4216a604. Interesting fixes: 76584a0 Reorganize code to use only 32bit atomic ops for 32bit platforms 30d2ae5 Implement __cxa_throw_bad_array_new_length Reviewed by: bapt Differential Revision: https://reviews.freebsd.org/D1390 MFC r277217: Import libc++ trunk r224926. This fixes a number of bugs, completes C++14 support[1], adds more C++1z features[2], and fixes the following LWG issues[3]: 1450: Contradiction in regex_constants 2003: String exception inconsistency in erase. 2075: Progress guarantees, lock-free property, and scheduling assumptions 2104: unique_lock move-assignment should not be noexcept 2112: User-defined classes that cannot be derived from 2132: std::function ambiguity 2135: Unclear requirement for exceptions thrown in condition_variable::wait() 2142: packaged_task::operator() synchronization too broad? 2182: Container::[const_]reference types are misleadingly specified 2186: Incomplete action on async/launch::deferred 2188: Reverse iterator does not fully support targets that overload operator& 2193: Default constructors for standard library containers are explicit 2205: Problematic postconditions of regex_match and regex_search 2213: Return value of std::regex_replace 2240: Probable misuse of term "function scope" in [thread.condition] 2252: Strong guarantee on vector::push_back() still broken with C++11? 2257: Simplify container requirements with the new algorithms 2258: a.erase(q1, q2) unable to directly return q2 2263: Comparing iterators and allocator pointers with different const-character 2268: Setting a default argument in the declaration of a member function assign of std::basic_string 2271: regex_traits::lookup_classname specification unclear 2272: quoted should use char_traits::eq for character comparison 2278: User-defined literals for Standard Library types 2280: begin / end for arrays should be constexpr and noexcept 2285: make_reverse_iterator 2288: Inconsistent requirements for shared mutexes 2291: std::hash is vulnerable to collision DoS attack 2293: Wrong facet used by num_put::do_put 2299: Effects of inaccessible key_compare::is_transparent type are not clear 2301: Why is std::tie not constexpr? 2304: Complexity of count in unordered associative containers 2306: match_results::reference should be value_type&, not const value_type& 2308: Clarify container destructor requirements w.r.t. std::array 2313: tuple_size should always derive from integral_constant<size_t, N> 2314: apply() should return decltype(auto) and use decay_t before tuple_size 2315: weak_ptr should be movable 2316: weak_ptr::lock() should be atomic 2317: The type property queries should be UnaryTypeTraits returning size_t 2320: select_on_container_copy_construction() takes allocators, not containers 2322: Associative(initializer_list, stuff) constructors are underspecified 2323: vector::resize(n, t)'s specification should be simplified 2324: Insert iterator constructors should use addressof() 2329: regex_match()/regex_search() with match_results should forbid temporary strings 2330: regex("meow", regex::icase) is technically forbidden but should be permitted 2332: regex_iterator/regex_token_iterator should forbid temporary regexes 2339: Wording issue in nth_element 2341: Inconsistency between basic_ostream::seekp(pos) and basic_ostream::seekp(off, dir) 2344: quoted()'s interaction with padding is unclear 2346: integral_constant's member functions should be marked noexcept 2350: min, max, and minmax should be constexpr 2356: Stability of erasure in unordered associative containers 2357: Remaining "Assignable" requirement 2359: How does regex_constants::nosubs affect basic_regex::mark_count()? 2360: reverse_iterator::operator*() is unimplementable [1] http://libcxx.llvm.org/cxx1y_status.html [2] http://libcxx.llvm.org/cxx1z_status.html [3] http://www.open-std.org/jtc1/sc22/wg21/docs/lwg-defects.html Exp-run: antoine MFC r277944: Partially revert r273382, to reduce diffs against upstream. This was a temporary fix to solve a conflict with an older version of libc++, and it is no longer relevant. MFC r278010: Revert r256642, not only to reduce diffs against upstream libcxxrt, but also because it is the wrong approach: comparing typeinfo names deeply causes trouble if two loaded DSOs use independent types of the same name. In addition, this particular change was never merged to FreeBSD 10.x and 9.x, so let's get rid of it before it ends up in an 11.x release. Discussed with: theraven, joerg@netbsd MFC r278016: Import libcxxrt master 1cb607e89f6135bbc10f3d3b6fba1f983e258dcc. Interesting fixes: 1cb607e Correct gcc version check for __cxa_begin_catch() declaration with or without throw()
245 lines
8.6 KiB
C++
245 lines
8.6 KiB
C++
/*
|
|
* Copyright 2012 David Chisnall. All rights reserved.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to
|
|
* deal in the Software without restriction, including without limitation the
|
|
* rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
|
|
* sell copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be
|
|
* included in all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
|
* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
|
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
|
* NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
|
* LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
|
* OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
|
* WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
|
*/
|
|
|
|
#ifndef __CXXABI_H_
|
|
#define __CXXABI_H_
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
#include "unwind.h"
|
|
namespace std
|
|
{
|
|
class type_info;
|
|
}
|
|
/*
|
|
* The cxxabi.h header provides a set of public definitions for types and
|
|
* functions defined by the Itanium C++ ABI specification. For reference, see
|
|
* the ABI specification here:
|
|
*
|
|
* http://sourcery.mentor.com/public/cxx-abi/abi.html
|
|
*
|
|
* All deviations from this specification, unless otherwise noted, are
|
|
* accidental.
|
|
*/
|
|
|
|
#ifdef __cplusplus
|
|
namespace __cxxabiv1 {
|
|
extern "C" {
|
|
#endif
|
|
/**
|
|
* Function type to call when an unexpected exception is encountered.
|
|
*/
|
|
typedef void (*unexpected_handler)();
|
|
/**
|
|
* Function type to call when an unrecoverable condition is encountered.
|
|
*/
|
|
typedef void (*terminate_handler)();
|
|
|
|
|
|
/**
|
|
* Structure used as a header on thrown exceptions. This is the same layout as
|
|
* defined by the Itanium ABI spec, so should be interoperable with any other
|
|
* implementation of this spec, such as GNU libsupc++.
|
|
*
|
|
* This structure is allocated when an exception is thrown. Unwinding happens
|
|
* in two phases, the first looks for a handler and the second installs the
|
|
* context. This structure stores a cache of the handler location between
|
|
* phase 1 and phase 2. Unfortunately, cleanup information is not cached, so
|
|
* must be looked up in both phases. This happens for two reasons. The first
|
|
* is that we don't know how many frames containing cleanups there will be, and
|
|
* we should avoid dynamic allocation during unwinding (the exception may be
|
|
* reporting that we've run out of memory). The second is that finding
|
|
* cleanups is much cheaper than finding handlers, because we don't have to
|
|
* look at the type table at all.
|
|
*
|
|
* Note: Several fields of this structure have not-very-informative names.
|
|
* These are taken from the ABI spec and have not been changed to make it
|
|
* easier for people referring to to the spec while reading this code.
|
|
*/
|
|
struct __cxa_exception
|
|
{
|
|
#if __LP64__
|
|
/**
|
|
* Reference count. Used to support the C++11 exception_ptr class. This
|
|
* is prepended to the structure in 64-bit mode and squeezed in to the
|
|
* padding left before the 64-bit aligned _Unwind_Exception at the end in
|
|
* 32-bit mode.
|
|
*
|
|
* Note that it is safe to extend this structure at the beginning, rather
|
|
* than the end, because the public API for creating it returns the address
|
|
* of the end (where the exception object can be stored).
|
|
*/
|
|
uintptr_t referenceCount;
|
|
#endif
|
|
/** Type info for the thrown object. */
|
|
std::type_info *exceptionType;
|
|
/** Destructor for the object, if one exists. */
|
|
void (*exceptionDestructor) (void *);
|
|
/** Handler called when an exception specification is violated. */
|
|
unexpected_handler unexpectedHandler;
|
|
/** Hander called to terminate. */
|
|
terminate_handler terminateHandler;
|
|
/**
|
|
* Next exception in the list. If an exception is thrown inside a catch
|
|
* block and caught in a nested catch, this points to the exception that
|
|
* will be handled after the inner catch block completes.
|
|
*/
|
|
__cxa_exception *nextException;
|
|
/**
|
|
* The number of handlers that currently have references to this
|
|
* exception. The top (non-sign) bit of this is used as a flag to indicate
|
|
* that the exception is being rethrown, so should not be deleted when its
|
|
* handler count reaches 0 (which it doesn't with the top bit set).
|
|
*/
|
|
int handlerCount;
|
|
#if defined(__arm__) && !defined(__ARM_DWARF_EH__)
|
|
/**
|
|
* The ARM EH ABI requires the unwind library to keep track of exceptions
|
|
* during cleanups. These support nesting, so we need to keep a list of
|
|
* them.
|
|
*/
|
|
_Unwind_Exception *nextCleanup;
|
|
/**
|
|
* The number of cleanups that are currently being run on this exception.
|
|
*/
|
|
int cleanupCount;
|
|
#endif
|
|
/**
|
|
* The selector value to be returned when installing the catch handler.
|
|
* Used at the call site to determine which catch() block should execute.
|
|
* This is found in phase 1 of unwinding then installed in phase 2.
|
|
*/
|
|
int handlerSwitchValue;
|
|
/**
|
|
* The action record for the catch. This is cached during phase 1
|
|
* unwinding.
|
|
*/
|
|
const char *actionRecord;
|
|
/**
|
|
* Pointer to the language-specific data area (LSDA) for the handler
|
|
* frame. This is unused in this implementation, but set for ABI
|
|
* compatibility in case we want to mix code in very weird ways.
|
|
*/
|
|
const char *languageSpecificData;
|
|
/** The cached landing pad for the catch handler.*/
|
|
void *catchTemp;
|
|
/**
|
|
* The pointer that will be returned as the pointer to the object. When
|
|
* throwing a class and catching a virtual superclass (for example), we
|
|
* need to adjust the thrown pointer to make it all work correctly.
|
|
*/
|
|
void *adjustedPtr;
|
|
#if !__LP64__
|
|
/**
|
|
* Reference count. Used to support the C++11 exception_ptr class. This
|
|
* is prepended to the structure in 64-bit mode and squeezed in to the
|
|
* padding left before the 64-bit aligned _Unwind_Exception at the end in
|
|
* 32-bit mode.
|
|
*
|
|
* Note that it is safe to extend this structure at the beginning, rather
|
|
* than the end, because the public API for creating it returns the address
|
|
* of the end (where the exception object can be stored)
|
|
*/
|
|
uintptr_t referenceCount;
|
|
#endif
|
|
/** The language-agnostic part of the exception header. */
|
|
_Unwind_Exception unwindHeader;
|
|
};
|
|
|
|
/**
|
|
* ABI-specified globals structure. Returned by the __cxa_get_globals()
|
|
* function and its fast variant. This is a per-thread structure - every
|
|
* thread will have one lazily allocated.
|
|
*
|
|
* This structure is defined by the ABI, so may be used outside of this
|
|
* library.
|
|
*/
|
|
struct __cxa_eh_globals
|
|
{
|
|
/**
|
|
* A linked list of exceptions that are currently caught. There may be
|
|
* several of these in nested catch() blocks.
|
|
*/
|
|
__cxa_exception *caughtExceptions;
|
|
/**
|
|
* The number of uncaught exceptions.
|
|
*/
|
|
unsigned int uncaughtExceptions;
|
|
};
|
|
/**
|
|
* ABI function returning the __cxa_eh_globals structure.
|
|
*/
|
|
__cxa_eh_globals *__cxa_get_globals(void);
|
|
/**
|
|
* Version of __cxa_get_globals() assuming that __cxa_get_globals() has already
|
|
* been called at least once by this thread.
|
|
*/
|
|
__cxa_eh_globals *__cxa_get_globals_fast(void);
|
|
|
|
std::type_info * __cxa_current_exception_type();
|
|
|
|
/**
|
|
* Throws an exception returned by __cxa_current_primary_exception(). This
|
|
* exception may have been caught in another thread.
|
|
*/
|
|
void __cxa_rethrow_primary_exception(void* thrown_exception);
|
|
/**
|
|
* Returns the current exception in a form that can be stored in an
|
|
* exception_ptr object and then rethrown by a call to
|
|
* __cxa_rethrow_primary_exception().
|
|
*/
|
|
void *__cxa_current_primary_exception(void);
|
|
/**
|
|
* Increments the reference count of an exception. Called when an
|
|
* exception_ptr is copied.
|
|
*/
|
|
void __cxa_increment_exception_refcount(void* thrown_exception);
|
|
/**
|
|
* Decrements the reference count of an exception. Called when an
|
|
* exception_ptr is deleted.
|
|
*/
|
|
void __cxa_decrement_exception_refcount(void* thrown_exception);
|
|
/**
|
|
* Demangles a C++ symbol or type name. The buffer, if non-NULL, must be
|
|
* allocated with malloc() and must be *n bytes or more long. This function
|
|
* may call realloc() on the value pointed to by buf, and will return the
|
|
* length of the string via *n.
|
|
*
|
|
* The value pointed to by status is set to one of the following:
|
|
*
|
|
* 0: success
|
|
* -1: memory allocation failure
|
|
* -2: invalid mangled name
|
|
* -3: invalid arguments
|
|
*/
|
|
char* __cxa_demangle(const char* mangled_name,
|
|
char* buf,
|
|
size_t* n,
|
|
int* status);
|
|
#ifdef __cplusplus
|
|
} // extern "C"
|
|
} // namespace
|
|
|
|
namespace abi = __cxxabiv1;
|
|
|
|
#endif /* __cplusplus */
|
|
#endif /* __CXXABI_H_ */
|