kernel/eka/compsupp/aehabi/cxxabi.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 17 Dec 2009 09:24:54 +0200
changeset 43 96e5fb8b040d
permissions -rw-r--r--
Revision: 200951 Kit: 200951

/* 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 */