summaryrefslogtreecommitdiffstats
path: root/clang/lib/Lex/Preprocessor.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2008-10-05 20:06:37 +0000
committerChris Lattner <sabre@nondot.org>2008-10-05 20:06:37 +0000
commit6512a889840e1402c922717ee7475cb261a43ea9 (patch)
tree440e60f5bc4d5d5e5fddd630fd9b51647fc7ec7d /clang/lib/Lex/Preprocessor.cpp
parent2b1ef227f53fe3250d5d61e0d2161a622b31692b (diff)
downloadbcm5719-llvm-6512a889840e1402c922717ee7475cb261a43ea9.tar.gz
bcm5719-llvm-6512a889840e1402c922717ee7475cb261a43ea9.zip
move a bunch more integer sizing out of target-specific code into
target indep code. Note that this changes functionality on PIC16: it defines __INT_MAX__ correctly for it, and it changes sizeof(long) to 16-bits (to match the size of pointer). llvm-svn: 57132
Diffstat (limited to 'clang/lib/Lex/Preprocessor.cpp')
-rw-r--r--clang/lib/Lex/Preprocessor.cpp49
1 files changed, 49 insertions, 0 deletions
diff --git a/clang/lib/Lex/Preprocessor.cpp b/clang/lib/Lex/Preprocessor.cpp
index 5d1f119c8cc..9758a586e4e 100644
--- a/clang/lib/Lex/Preprocessor.cpp
+++ b/clang/lib/Lex/Preprocessor.cpp
@@ -477,10 +477,59 @@ static void InitializePredefinedMacros(Preprocessor &PP,
DefineBuiltinMacro(Buf, "__CHAR_BIT__=8");
DefineBuiltinMacro(Buf, "__SHRT_MAX__=32767");
+ if (TI.getIntWidth() == 32)
+ DefineBuiltinMacro(Buf, "__INT_MAX__=2147483647");
+ else if (TI.getIntWidth() == 16)
+ DefineBuiltinMacro(Buf, "__INT_MAX__=32767");
+ else
+ assert(0 && "Unknown integer size");
assert(TI.getLongLongWidth() == 64 && "Only support 64-bit long long so far");
DefineBuiltinMacro(Buf, "__LONG_LONG_MAX__=9223372036854775807LL");
+ if (TI.getLongWidth() == 32)
+ DefineBuiltinMacro(Buf, "__LONG_MAX__=2147483647L");
+ else if (TI.getLongWidth() == 64)
+ DefineBuiltinMacro(Buf, "__LONG_MAX__=9223372036854775807L");
+ else if (TI.getLongWidth() == 16)
+ DefineBuiltinMacro(Buf, "__LONG_MAX__=32767L");
+ else
+ assert(0 && "Unknown long size");
+
+ // For "32-bit" targets, GCC generally defines intmax to be 'long long' and
+ // ptrdiff_t to be 'int'. On "64-bit" targets, it defines intmax to be long,
+ // and ptrdiff_t to be 'long int'. This sort of stuff shouldn't matter in
+ // theory, but can affect C++ overloading, stringizing, etc.
+ if (TI.getPointerWidth(0) == TI.getLongLongWidth()) {
+ // If sizeof(void*) == sizeof(long long) assume we have an LP64 target,
+ // because we assume sizeof(long) always is sizeof(void*) currently.
+ assert(TI.getPointerWidth(0) == TI.getLongWidth() &&
+ TI.getLongWidth() == 64 &&
+ TI.getIntWidth() == 32 && "Not I32 LP64?");
+ DefineBuiltinMacro(Buf, "__INTMAX_MAX__=9223372036854775807L");
+ DefineBuiltinMacro(Buf, "__INTMAX_TYPE__=long int");
+ DefineBuiltinMacro(Buf, "__PTRDIFF_TYPE__=long int");
+ DefineBuiltinMacro(Buf, "__UINTMAX_TYPE__=long unsigned int");
+ } else {
+ // Otherwise we know that the pointer is smaller than long long. We continue
+ // to assume that sizeof(void*) == sizeof(long).
+ assert(TI.getPointerWidth(0) < TI.getLongLongWidth() &&
+ TI.getPointerWidth(0) == TI.getLongWidth() &&
+ "Unexpected target sizes");
+ // We currently only support targets where long is 32-bit. This can be
+ // easily generalized in the future.
+ DefineBuiltinMacro(Buf, "__INTMAX_MAX__=9223372036854775807LL");
+ DefineBuiltinMacro(Buf, "__INTMAX_TYPE__=long long int");
+ DefineBuiltinMacro(Buf, "__PTRDIFF_TYPE__=int");
+ DefineBuiltinMacro(Buf, "__UINTMAX_TYPE__=long long unsigned int");
+ }
+
+ // All of our current targets have sizeof(long) == sizeof(void*).
+ assert(TI.getPointerWidth(0) == TI.getLongWidth());
+ DefineBuiltinMacro(Buf, "__SIZE_TYPE__=long unsigned int");
+
+
+
// Add __builtin_va_list typedef.
{
OpenPOWER on IntegriCloud