diff --git a/clang/lib/AST/ASTContext.cpp b/clang/lib/AST/ASTContext.cpp index 8fd088a305f1..12bbee2d9fc5 100644 --- a/clang/lib/AST/ASTContext.cpp +++ b/clang/lib/AST/ASTContext.cpp @@ -354,11 +354,7 @@ const ASTRecordLayout &ASTContext::getASTRecordLayout(const RecordDecl *D) { else if (FieldIsPacked) FieldAlign = 8; else { - // FIXME: This is X86 specific, use 32-bit alignment for long long. - if (FD->getType()->isIntegerType() && TypeInfo.second > 32) - FieldAlign = 32; - else - FieldAlign = TypeInfo.second; + FieldAlign = TypeInfo.second; } // Check if we need to add padding to give the field the correct @@ -418,17 +414,13 @@ const ASTRecordLayout &ASTContext::getASTRecordLayout(const RecordDecl *D) { std::pair FieldInfo = getTypeInfo(FD->getType()); uint64_t FieldSize = FieldInfo.first; unsigned FieldAlign = FieldInfo.second; - - // FIXME: This is X86 specific, use 32-bit alignment for long long. - if (FD->getType()->isIntegerType() && FieldAlign > 32) - FieldAlign = 32; // Round up the current record size to the field's alignment boundary. RecordSize = std::max(RecordSize, FieldSize); - + // Place this field at the start of the record. FieldOffsets[i] = 0; - + // Remember max struct/class alignment. RecordAlign = std::max(RecordAlign, FieldAlign); }