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