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 | f122cef4df04d017c1e43b9c6444c4e8e1a5b3ed (patch) | |
| tree | b0662fcfbbec40cd88ee5ed2c1e5914663a68c97 /clang/lib | |
| parent | 7216b9da5f20226dd11bdf109bd9fb84463852ee (diff) | |
| download | bcm5719-llvm-f122cef4df04d017c1e43b9c6444c4e8e1a5b3ed.tar.gz bcm5719-llvm-f122cef4df04d017c1e43b9c6444c4e8e1a5b3ed.zip | |
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.
llvm-svn: 70464
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/AST/ASTContext.cpp | 18 | ||||
| -rw-r--r-- | clang/lib/AST/Type.cpp | 4 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CGCall.cpp | 4 | ||||
| -rw-r--r-- | clang/lib/CodeGen/CodeGenTypes.cpp | 4 | ||||
| -rw-r--r-- | clang/lib/CodeGen/Mangle.cpp | 2 | ||||
| -rw-r--r-- | clang/lib/Frontend/PCHReader.cpp | 2 | ||||
| -rw-r--r-- | clang/lib/Frontend/PCHWriter.cpp | 2 | ||||
| -rw-r--r-- | clang/lib/Sema/Sema.cpp | 12 |
8 files changed, 46 insertions, 2 deletions
diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index 58fc42b036b..6cd016cab81 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -251,6 +251,10 @@ void ASTContext::InitBuiltinTypes() { InitBuiltinType(DoubleTy, BuiltinType::Double); InitBuiltinType(LongDoubleTy, BuiltinType::LongDouble); + // GNU extension, 128-bit integers. + InitBuiltinType(Int128Ty, BuiltinType::Int128); + InitBuiltinType(UnsignedInt128Ty, BuiltinType::UInt128); + if (LangOpts.CPlusPlus) // C++ 3.9.1p5 InitBuiltinType(WCharTy, BuiltinType::WChar); else // C99 @@ -421,6 +425,13 @@ ASTContext::getTypeInfo(const Type *T) { Width = Target.getLongDoubleWidth(); Align = Target.getLongDoubleAlign(); break; + case BuiltinType::Int128: + case BuiltinType::UInt128: + Width = 128; + + // FIXME: Is this correct for all targets? + Align = 128; + break; } break; case Type::FixedWidthInt: @@ -1923,6 +1934,9 @@ unsigned ASTContext::getIntegerRank(Type *T) { case BuiltinType::LongLong: case BuiltinType::ULongLong: return 6 + (getIntWidth(LongLongTy) << 3); + case BuiltinType::Int128: + case BuiltinType::UInt128: + return 7 + (getIntWidth(Int128Ty) << 3); } } @@ -2291,6 +2305,7 @@ void ASTContext::getObjCEncodingForTypeImpl(QualType T, std::string& S, encoding = (const_cast<ASTContext *>(this))->getIntWidth(T) == 32 ? 'L' : 'Q'; break; + case BuiltinType::UInt128: encoding = 'T'; break; case BuiltinType::ULongLong: encoding = 'Q'; break; case BuiltinType::Char_S: case BuiltinType::SChar: encoding = 'c'; break; @@ -2301,6 +2316,7 @@ void ASTContext::getObjCEncodingForTypeImpl(QualType T, std::string& S, (const_cast<ASTContext *>(this))->getIntWidth(T) == 32 ? 'l' : 'q'; break; case BuiltinType::LongLong: encoding = 'q'; break; + case BuiltinType::Int128: encoding = 't'; break; case BuiltinType::Float: encoding = 'f'; break; case BuiltinType::Double: encoding = 'd'; break; case BuiltinType::LongDouble: encoding = 'd'; break; @@ -3244,6 +3260,8 @@ QualType ASTContext::getCorrespondingUnsignedType(QualType T) { return UnsignedLongTy; case BuiltinType::LongLong: return UnsignedLongLongTy; + case BuiltinType::Int128: + return UnsignedInt128Ty; default: assert(0 && "Unexpected signed integer type"); return QualType(); diff --git a/clang/lib/AST/Type.cpp b/clang/lib/AST/Type.cpp index 0331bbf40dd..d6cf4bd0c35 100644 --- a/clang/lib/AST/Type.cpp +++ b/clang/lib/AST/Type.cpp @@ -584,7 +584,7 @@ Type::getAsTemplateSpecializationType() const { bool Type::isIntegerType() const { if (const BuiltinType *BT = dyn_cast<BuiltinType>(CanonicalType)) return BT->getKind() >= BuiltinType::Bool && - BT->getKind() <= BuiltinType::LongLong; + BT->getKind() <= BuiltinType::Int128; if (const TagType *TT = dyn_cast<TagType>(CanonicalType)) // Incomplete enum types are not treated as integer types. // FIXME: In C++, enum types are never integer types. @@ -901,11 +901,13 @@ const char *BuiltinType::getName() const { case Int: return "int"; case Long: return "long"; case LongLong: return "long long"; + case Int128: return "__int128_t"; case UChar: return "unsigned char"; case UShort: return "unsigned short"; case UInt: return "unsigned int"; case ULong: return "unsigned long"; case ULongLong: return "unsigned long long"; + case UInt128: return "__uint128_t"; case Float: return "float"; case Double: return "double"; case LongDouble: return "long double"; diff --git a/clang/lib/CodeGen/CGCall.cpp b/clang/lib/CodeGen/CGCall.cpp index 07663bfaea4..a6439fcb036 100644 --- a/clang/lib/CodeGen/CGCall.cpp +++ b/clang/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); diff --git a/clang/lib/CodeGen/CodeGenTypes.cpp b/clang/lib/CodeGen/CodeGenTypes.cpp index f0bc6f69613..a3f79d3d59c 100644 --- a/clang/lib/CodeGen/CodeGenTypes.cpp +++ b/clang/lib/CodeGen/CodeGenTypes.cpp @@ -256,6 +256,10 @@ const llvm::Type *CodeGenTypes::ConvertNewType(QualType T) { case BuiltinType::Double: case BuiltinType::LongDouble: return getTypeForFormat(Context.getFloatTypeSemantics(T)); + + case BuiltinType::UInt128: + case BuiltinType::Int128: + return llvm::IntegerType::get(128); } break; } diff --git a/clang/lib/CodeGen/Mangle.cpp b/clang/lib/CodeGen/Mangle.cpp index 3a7fe9c1f79..e6d643f7ca8 100644 --- a/clang/lib/CodeGen/Mangle.cpp +++ b/clang/lib/CodeGen/Mangle.cpp @@ -508,12 +508,14 @@ void CXXNameMangler::mangleType(const BuiltinType *T) { case BuiltinType::UInt: Out << 'j'; break; case BuiltinType::ULong: Out << 'm'; break; case BuiltinType::ULongLong: Out << 'y'; break; + case BuiltinType::UInt128: Out << 'o'; break; case BuiltinType::SChar: Out << 'a'; break; case BuiltinType::WChar: Out << 'w'; break; case BuiltinType::Short: Out << 's'; break; case BuiltinType::Int: Out << 'i'; break; case BuiltinType::Long: Out << 'l'; break; case BuiltinType::LongLong: Out << 'x'; break; + case BuiltinType::Int128: Out << 'n'; break; case BuiltinType::Float: Out << 'f'; break; case BuiltinType::Double: Out << 'd'; break; case BuiltinType::LongDouble: Out << 'e'; break; diff --git a/clang/lib/Frontend/PCHReader.cpp b/clang/lib/Frontend/PCHReader.cpp index ead6dcc1016..93236209380 100644 --- a/clang/lib/Frontend/PCHReader.cpp +++ b/clang/lib/Frontend/PCHReader.cpp @@ -1663,12 +1663,14 @@ QualType PCHReader::GetType(pch::TypeID ID) { case pch::PREDEF_TYPE_UINT_ID: T = Context->UnsignedIntTy; break; case pch::PREDEF_TYPE_ULONG_ID: T = Context->UnsignedLongTy; break; case pch::PREDEF_TYPE_ULONGLONG_ID: T = Context->UnsignedLongLongTy; break; + case pch::PREDEF_TYPE_UINT128_ID: T = Context->UnsignedInt128Ty; break; case pch::PREDEF_TYPE_SCHAR_ID: T = Context->SignedCharTy; break; case pch::PREDEF_TYPE_WCHAR_ID: T = Context->WCharTy; break; case pch::PREDEF_TYPE_SHORT_ID: T = Context->ShortTy; break; case pch::PREDEF_TYPE_INT_ID: T = Context->IntTy; break; case pch::PREDEF_TYPE_LONG_ID: T = Context->LongTy; break; case pch::PREDEF_TYPE_LONGLONG_ID: T = Context->LongLongTy; break; + case pch::PREDEF_TYPE_INT128_ID: T = Context->Int128Ty; break; case pch::PREDEF_TYPE_FLOAT_ID: T = Context->FloatTy; break; case pch::PREDEF_TYPE_DOUBLE_ID: T = Context->DoubleTy; break; case pch::PREDEF_TYPE_LONGDOUBLE_ID: T = Context->LongDoubleTy; break; diff --git a/clang/lib/Frontend/PCHWriter.cpp b/clang/lib/Frontend/PCHWriter.cpp index 8374e092a53..b28d0c8cf9f 100644 --- a/clang/lib/Frontend/PCHWriter.cpp +++ b/clang/lib/Frontend/PCHWriter.cpp @@ -1829,6 +1829,7 @@ void PCHWriter::AddTypeRef(QualType T, RecordData &Record) { case BuiltinType::UInt: ID = pch::PREDEF_TYPE_UINT_ID; break; case BuiltinType::ULong: ID = pch::PREDEF_TYPE_ULONG_ID; break; case BuiltinType::ULongLong: ID = pch::PREDEF_TYPE_ULONGLONG_ID; break; + case BuiltinType::UInt128: ID = pch::PREDEF_TYPE_UINT128_ID; break; case BuiltinType::Char_S: ID = pch::PREDEF_TYPE_CHAR_S_ID; break; case BuiltinType::SChar: ID = pch::PREDEF_TYPE_SCHAR_ID; break; case BuiltinType::WChar: ID = pch::PREDEF_TYPE_WCHAR_ID; break; @@ -1836,6 +1837,7 @@ void PCHWriter::AddTypeRef(QualType T, RecordData &Record) { case BuiltinType::Int: ID = pch::PREDEF_TYPE_INT_ID; break; case BuiltinType::Long: ID = pch::PREDEF_TYPE_LONG_ID; break; case BuiltinType::LongLong: ID = pch::PREDEF_TYPE_LONGLONG_ID; break; + case BuiltinType::Int128: ID = pch::PREDEF_TYPE_INT128_ID; break; case BuiltinType::Float: ID = pch::PREDEF_TYPE_FLOAT_ID; break; case BuiltinType::Double: ID = pch::PREDEF_TYPE_DOUBLE_ID; break; case BuiltinType::LongDouble: ID = pch::PREDEF_TYPE_LONGDOUBLE_ID; break; diff --git a/clang/lib/Sema/Sema.cpp b/clang/lib/Sema/Sema.cpp index 367c9f5756b..8ce3ce0be63 100644 --- a/clang/lib/Sema/Sema.cpp +++ b/clang/lib/Sema/Sema.cpp @@ -108,6 +108,18 @@ static inline RecordDecl *CreateStructDecl(ASTContext &C, const char *Name) { void Sema::ActOnTranslationUnitScope(SourceLocation Loc, Scope *S) { TUScope = S; PushDeclContext(S, Context.getTranslationUnitDecl()); + + // Install [u]int128_t. + PushOnScopeChains(TypedefDecl::Create(Context, CurContext, + SourceLocation(), + &Context.Idents.get("__int128_t"), + Context.Int128Ty), TUScope); + PushOnScopeChains(TypedefDecl::Create(Context, CurContext, + SourceLocation(), + &Context.Idents.get("__uint128_t"), + Context.UnsignedInt128Ty), TUScope); + + if (!PP.getLangOptions().ObjC1) return; if (Context.getObjCSelType().isNull()) { |

