diff options
author | Chris Lattner <sabre@nondot.org> | 2009-04-30 02:43:43 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-04-30 02:43:43 +0000 |
commit | 2df9ced9fd1e8c7d7b38443db07e0e811de22571 (patch) | |
tree | c5cb423c1cc8fe563f15be09e5a3e6612763b643 /lib/CodeGen/CGCall.cpp | |
parent | 5532180ae3fa5b3bfa0b2177f08c94075641e8bb (diff) |
initial support for __[u]int128_t, which should be basically
compatible with VC++ and GCC. The codegen/mangling angle hasn't
been fully ironed out yet. Note that we accept int128_t even in
32-bit mode, unlike gcc.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@70464 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGCall.cpp')
-rw-r--r-- | lib/CodeGen/CGCall.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/lib/CodeGen/CGCall.cpp b/lib/CodeGen/CGCall.cpp index 07663bfaea..a6439fcb03 100644 --- a/lib/CodeGen/CGCall.cpp +++ b/lib/CodeGen/CGCall.cpp @@ -640,6 +640,9 @@ void X86_64ABIInfo::classify(QualType Ty, if (k == BuiltinType::Void) { Current = NoClass; + } else if (k == BuiltinType::Int128 || k == BuiltinType::UInt128) { + Lo = Memory; + Hi = Memory; } else if (k >= BuiltinType::Bool && k <= BuiltinType::LongLong) { Current = Integer; } else if (k == BuiltinType::Float || k == BuiltinType::Double) { @@ -650,7 +653,6 @@ void X86_64ABIInfo::classify(QualType Ty, } // FIXME: _Decimal32 and _Decimal64 are SSE. // FIXME: _float128 and _Decimal128 are (SSE, SSEUp). - // FIXME: __int128 is (Integer, Integer). } else if (const EnumType *ET = Ty->getAsEnumType()) { // Classify the underlying integer type. classify(ET->getDecl()->getIntegerType(), Context, OffsetBase, Lo, Hi); |