sl@0: /* Copyright (c) Edison Design Group, 2002. */ sl@0: /* sl@0: cxxabi.h -- Include file for IA-64 ABI entry points. sl@0: */ sl@0: sl@0: #ifndef __CXXABI_H sl@0: #define __CXXABI_H sl@0: sl@0: #ifndef __STDDEF_H sl@0: #include sl@0: #endif /* ifndef __STDDEF_H */ sl@0: #include sl@0: sl@0: #ifdef __EDG_RUNTIME_USES_NAMESPACES sl@0: namespace __cxxabiv1 { sl@0: using namespace std; sl@0: #endif /* ifdef __EDG_RUNTIME_USES_NAMESPACES */ sl@0: sl@0: /* type_info implementation classes */ sl@0: sl@0: #pragma define_type_info sl@0: class __fundamental_type_info : public type_info { sl@0: public: sl@0: virtual ~__fundamental_type_info(); sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __array_type_info : public type_info { sl@0: public: sl@0: virtual ~__array_type_info(); sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __function_type_info : public type_info { sl@0: public: sl@0: virtual ~__function_type_info(); sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __enum_type_info : public type_info { sl@0: public: sl@0: virtual ~__enum_type_info(); sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __class_type_info : public type_info { sl@0: public: sl@0: virtual ~__class_type_info(); sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __si_class_type_info : public __class_type_info { sl@0: public: sl@0: virtual ~__si_class_type_info(); sl@0: const __class_type_info *__base_type; sl@0: }; sl@0: sl@0: struct __base_class_type_info { sl@0: const __class_type_info *__base_type; sl@0: long __offset_flags; sl@0: sl@0: enum __offset_flags_masks { sl@0: __virtual_mask = 0x1, sl@0: __public_mask = 0x2, sl@0: __offset_shift = 8 sl@0: }; sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __vmi_class_type_info : public __class_type_info { sl@0: public: sl@0: virtual ~__vmi_class_type_info(); sl@0: unsigned int __flags; sl@0: unsigned int __base_count; sl@0: __base_class_type_info __base_info[1]; sl@0: sl@0: enum __flags_masks { sl@0: __non_diamond_repeat_mask = 0x1, sl@0: __diamond_shaped_mask = 0x2 sl@0: }; sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __pbase_type_info : public type_info { sl@0: public: sl@0: virtual ~__pbase_type_info(); sl@0: unsigned int __flags; sl@0: const type_info *__pointee; sl@0: sl@0: enum __masks { sl@0: __const_mask = 0x1, sl@0: __volatile_mask = 0x2, sl@0: __restrict_mask = 0x4, sl@0: __incomplete_mask = 0x8, sl@0: __incomplete_class_mask = 0x10 sl@0: }; sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __pointer_type_info : public __pbase_type_info { sl@0: virtual ~__pointer_type_info(); sl@0: }; sl@0: sl@0: #pragma define_type_info sl@0: class __pointer_to_member_type_info : public __pbase_type_info { sl@0: virtual ~__pointer_to_member_type_info(); sl@0: const __class_type_info *__context; sl@0: }; sl@0: sl@0: extern "C" { sl@0: /* Pure virtual function calls. */ sl@0: void __cxa_pure_virtual(); sl@0: sl@0: /* Guard variables for the initialization of variables with static storage sl@0: duration. */ sl@0: #ifdef __CXXABI_USING_64BIT_GUARD_VARIABLES sl@0: int __cxa_guard_acquire(unsigned long long *); sl@0: void __cxa_guard_release(unsigned long long *); sl@0: void __cxa_guard_abort(unsigned long long *); sl@0: #else sl@0: // C++ ABI for ARM uses 32 bit guard variables sl@0: int __cxa_guard_acquire(int *); sl@0: void __cxa_guard_release(int *); sl@0: void __cxa_guard_abort(int *); sl@0: #endif sl@0: sl@0: // define the 'Structor Return Type sl@0: #ifndef __CXXABI_STORS_RETURN_VOID sl@0: typedef void* SRT; // under C++ ABI for ARM 'structors return 'void *' sl@0: #else sl@0: typedef void SRT; // 'structors return 'void' sl@0: #endif sl@0: sl@0: /* Construction and destruction of arrays. */ sl@0: void *__cxa_vec_new(size_t, size_t, size_t, SRT (*)(void *), sl@0: SRT (*)(void *)); sl@0: void *__cxa_vec_new2(size_t, size_t, size_t, SRT (*)(void *), sl@0: SRT (*)(void *), void *(*)(size_t), sl@0: void (*)(void *)); sl@0: void *__cxa_vec_new3(size_t, size_t, size_t, SRT (*)(void *), sl@0: SRT (*)(void *), void *(*)(size_t), sl@0: void (*)(void *, size_t)); sl@0: #ifndef CXXABI_VEC_CTOR_RETURNS_VOID sl@0: /* The C++ ABI says this returns 'void' but we actually return sl@0: 'void *' to remain compatible with RVCT 2.0 objects. But the sl@0: compiler no longer assumes it. */ sl@0: void * sl@0: #else /* def CXXABI_VEC_CTOR_RETURNS_VOID */ sl@0: void sl@0: #endif /* def CXXABI_VEC_CTOR_RETURNS_VOID */ sl@0: __cxa_vec_ctor(void *, size_t, size_t, SRT (*)(void *), sl@0: SRT (*)(void *)); sl@0: void __cxa_vec_dtor(void *, size_t, size_t, SRT (*)(void *)); sl@0: void __cxa_vec_cleanup(void *, size_t, size_t, SRT (*)(void *)); sl@0: void __cxa_vec_delete(void *, size_t, size_t, SRT (*)(void *)); sl@0: void __cxa_vec_delete2(void *, size_t, size_t, SRT (*)(void *), sl@0: void (*)(void *)); sl@0: void __cxa_vec_delete3(void *, size_t, size_t, SRT (*)(void *), sl@0: void (*)(void *, size_t)); sl@0: #ifndef CXXABI_VEC_CTOR_RETURNS_VOID sl@0: /* The C++ ABI says this returns 'void' but we actually return sl@0: 'void *' to remain compatible with RVCT 2.0 objects. But the sl@0: compiler no longer assumes it. */ sl@0: void * sl@0: #else /* def CXXABI_VEC_CTOR_RETURNS_VOID */ sl@0: void sl@0: #endif /* def CXXABI_VEC_CTOR_RETURNS_VOID */ sl@0: __cxa_vec_cctor(void *, void *, size_t, size_t, sl@0: SRT (*)(void *, void *), SRT (*)(void *)); sl@0: sl@0: /* Finalization. */ sl@0: int __cxa_atexit(void (*)(void *), void *, void *); sl@0: void __cxa_finalize(void *); sl@0: sl@0: /* Exception-handling support. */ sl@0: void __cxa_bad_cast(); sl@0: void __cxa_bad_typeid(); sl@0: sl@0: /* Demangling interface. */ sl@0: char *__cxa_demangle(const char* __mangled_name, sl@0: char *__buf, sl@0: size_t *__n, sl@0: int *__status); sl@0: sl@0: } /* extern "C" */ sl@0: #ifdef __EDG_RUNTIME_USES_NAMESPACES sl@0: } /* namespace __cxxabiv1 */ sl@0: sl@0: /* Create the "abi" namespace alias. */ sl@0: namespace abi = __cxxabiv1; sl@0: #endif /* ifdef __EDG_RUNTIME_USES_NAMESPACES */ sl@0: sl@0: #endif /* ifndef __CXXABI_H */