author | William Roberts <williamr@symbian.org> |
Mon, 28 Jun 2010 11:25:30 +0100 | |
branch | GCC_SURGE |
changeset 184 | 0e2270015475 |
parent 156 | 12b6722e7753 |
permissions | -rw-r--r-- |
// Copyright (c) 2002-2009 Nokia Corporation and/or its subsidiary(-ies). // All rights reserved. // This component and the accompanying materials are made available // under the terms of the License "ARM EABI LICENCE.txt" // which accompanies this distribution, and is available // in kernel/eka/compsupp. // // Initial Contributors: // Nokia Corporation - initial contribution. // // Contributors: // // Description: // e32\compsupp\rvct2_1\rvct2_1.h // This is the preinclude file for the rvct 2.1 compiler // It contains all the compiler specific definitions required by the SOS source // // /** @file @publishedAll @released */ #ifdef __ARMCC_VERSION #if (__ARMCC_VERSION < 210000 || __ARMCC_VERSION >= 220000) #error This instantiation of the build requires use of RVCT 2.1 #endif #endif #if defined(__PRODUCT_INCLUDE__) #include __PRODUCT_INCLUDE__ #endif // stuff from e32def.h #define __NO_CLASS_CONSTS__ #define __NORETURN__ __declspec(noreturn) #define __NORETURN_TERMINATOR() #define IMPORT_C __declspec(dllimport) #define EXPORT_C __declspec(dllexport) /** Declares a class as being non-sharable. If a class is non-sharable, then a class implemented in another DLL cannot derive (inherit) from that class. Declaring a class as non-sharable prevents the compiler from exporting compiler implementation-specific symbols, i.e. run-time type-information and virtual tables. This prevents classes in other DLLs from being able to derive from it. Note : - if a class is marked as non-sharable, then Symbian OS requires all classes that are derived from that class, and which are also implemented in the same DLL, to be declared as non-sharable. - by default, a class is sharable. The following code fragment shows how a non-sharable class is declared. @code NONSHARABLE_CLASS(CMyClass) : public CBase { public : ... private : ... } @endcode @param x The name of the class to be declared as non-sharable. */ #define NONSHARABLE_CLASS(x) class __declspec(notshared) x #define NONSHARABLE_STRUCT(x) struct __declspec(notshared) x #define __NO_THROW throw () #define __THROW(t) throw (t) #define TEMPLATE_SPECIALIZATION template<> #ifndef __int64 #define __int64 long long #endif #define __VALUE_IN_REGS__ __value_in_regs #define I64LIT(x) x##LL #define UI64LIT(x) x##ULL #define __SOFTFP __softfp // __TText from e32cmn.h also e32des16.h #ifdef __cplusplus typedef wchar_t __TText; // Only ISO C++ has wchar_t as a primitive type #define __wchar_t_defined #else typedef unsigned short __TText; #endif #define __TText_defined // __NAKED__ from cpudefs.h #define __NAKED__ __asm #define ____ONLY_USE_NAKED_IN_CIA____ __asm // Int64 and Uint64 from nkern\nklib.h typedef long long Int64; typedef unsigned long long Uint64; // Here are RVCT 2.0's definitions for stdarg.h // These should be used by e.g. stdlib // see if we're using the BETA B compiler #if (__ARMCC_VERSION == 200022) #define RVCTBETA #endif #ifdef __cplusplus namespace std { extern "C" { #endif /* __cplusplus */ #ifdef RVCTBETA typedef int *va_list[1]; #else typedef struct __va_list { void *__ap; } va_list; #endif #ifdef __cplusplus } /* extern "C" */ } /* namespace std */ using ::std::va_list; #endif #define va_start(ap, parmN) __va_start(ap, parmN) #define va_arg(ap, type) __va_arg(ap, type) #define va_end(ap) ((void)0) // These are for Symbian OS C++ code #define VA_START(ap,pn) va_start(ap, pn) #define VA_ARG(ap,type) va_arg(ap,type) #define VA_END(ap) va_end(ap) #define VA_LIST va_list #define __VA_LIST_defined // This should prevent /stdlib/linc/stdarg.h from doing damage. #define _STDARG_H // now deal with stdarg_e.h typedef va_list __e32_va_list; #define _STDARG_E_H // This is an EABI compliant compiler #ifndef __EABI__ #define __EABI__ #endif // these are hopefully temporary // defining this means we don't get __NAKED__ ctors #ifndef __EABI_CTORS__ #define __EABI_CTORS__ #endif //#define __EARLY_DEBUG__ // Deal with operator new issues here #ifdef __cplusplus namespace std { struct nothrow_t { }; extern const nothrow_t nothrow; } IMPORT_C void* operator new(unsigned int aSize) __NO_THROW; IMPORT_C void* operator new[](unsigned int aSize) __NO_THROW; IMPORT_C void* operator new(unsigned int aSize, const std::nothrow_t& aNoThrow) __NO_THROW; IMPORT_C void* operator new[](unsigned int aSize, const std::nothrow_t& aNoThrow) __NO_THROW; IMPORT_C void operator delete(void* aPtr) __NO_THROW; IMPORT_C void operator delete[](void* aPtr) __NO_THROW; IMPORT_C void operator delete(void* aPtr, const std::nothrow_t& aNoThrow) __NO_THROW; IMPORT_C void operator delete[](void* aPtr, const std::nothrow_t& aNoThrow) __NO_THROW; // Support for throwing exceptions through embedded assembler // Should only be needed user side #define __EH_FRAME_ADDRESS(reg,offset) FRAME ADDRESS reg, offset #define __EH_FRAME_PUSH2(reg1,reg2) FRAME PUSH {reg1, reg2} #define __EH_FRAME_SAVE1(reg,offset) FRAME SAVE {reg}, offset #define __EH_FNSTART #define __EH_FNEND #endif