Frontend: define _LP64 in a target-independent way
Instead of adding it to each individual subclass in Targets.cpp, simply check the appropriate target values. Where before it was only on x86_64 and ppc64, it's now also defined on mips64 and nvptx64. Also add a bunch of negative tests to ensure it is *not* defined on any other architectures while we're here. llvm-svn: 161685
This commit is contained in:
@@ -458,6 +458,13 @@ static void InitializePredefinedMacros(const TargetInfo &TI,
|
||||
else
|
||||
Builder.defineMacro("__BYTE_ORDER__", "__ORDER_LITTLE_ENDIAN__");
|
||||
|
||||
|
||||
if (TI.getPointerWidth(0) == 64 && TI.getLongWidth() == 64
|
||||
&& TI.getIntWidth() == 32) {
|
||||
Builder.defineMacro("_LP64");
|
||||
Builder.defineMacro("__LP64__");
|
||||
}
|
||||
|
||||
// Define type sizing macros based on the target properties.
|
||||
assert(TI.getCharWidth() == 8 && "Only support 8-bit char so far");
|
||||
Builder.defineMacro("__CHAR_BIT__", "8");
|
||||
|
||||
Reference in New Issue
Block a user