diff options
author | Ken Dyck <kd@kendyck.com> | 2011-02-01 01:52:10 +0000 |
---|---|---|
committer | Ken Dyck <kd@kendyck.com> | 2011-02-01 01:52:10 +0000 |
commit | 5c3633fa57f27b0909ab5767715c4e66b8920165 (patch) | |
tree | 5a2625537ff37e71fef7c6fbf5b8910f28eb4134 /lib/CodeGen/CGRecordLayoutBuilder.cpp | |
parent | 65e7a9e0597fdd68caa23d49991f3891e724e5c6 (diff) |
Convert RecordLayout::NonVirtualSize from bit units to CharUnits.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@124646 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/CGRecordLayoutBuilder.cpp')
-rw-r--r-- | lib/CodeGen/CGRecordLayoutBuilder.cpp | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/lib/CodeGen/CGRecordLayoutBuilder.cpp b/lib/CodeGen/CGRecordLayoutBuilder.cpp index 5571e43f78..b9b8c9d073 100644 --- a/lib/CodeGen/CGRecordLayoutBuilder.cpp +++ b/lib/CodeGen/CGRecordLayoutBuilder.cpp @@ -500,12 +500,12 @@ void CGRecordLayoutBuilder::LayoutBase(const CXXRecordDecl *BaseDecl, const ASTRecordLayout &Layout = Types.getContext().getASTRecordLayout(BaseDecl); - uint64_t NonVirtualSize = Layout.getNonVirtualSize(); + CharUnits NonVirtualSize = Layout.getNonVirtualSize(); AppendPadding(BaseOffset / 8, 1); // FIXME: Actually use a better type than [sizeof(BaseDecl) x i8] when we can. - AppendBytes(NonVirtualSize / 8); + AppendBytes(NonVirtualSize.getQuantity()); } void @@ -520,12 +520,12 @@ CGRecordLayoutBuilder::LayoutVirtualBase(const CXXRecordDecl *BaseDecl, const ASTRecordLayout &Layout = Types.getContext().getASTRecordLayout(BaseDecl); - uint64_t NonVirtualSize = Layout.getNonVirtualSize(); + CharUnits NonVirtualSize = Layout.getNonVirtualSize(); AppendPadding(BaseOffset / 8, 1); // FIXME: Actually use a better type than [sizeof(BaseDecl) x i8] when we can. - AppendBytes(NonVirtualSize / 8); + AppendBytes(NonVirtualSize.getQuantity()); // FIXME: Add the vbase field info. } @@ -616,8 +616,9 @@ bool CGRecordLayoutBuilder::ComputeNonVirtualBaseType(const CXXRecordDecl *RD) { const ASTRecordLayout &Layout = Types.getContext().getASTRecordLayout(RD); + uint64_t AlignedNonVirtualTypeSize = - llvm::RoundUpToAlignment(Layout.getNonVirtualSize(), + llvm::RoundUpToAlignment(Layout.getNonVirtualSize().getQuantity() * 8, Layout.getNonVirtualAlign()) / 8; @@ -855,7 +856,7 @@ CGRecordLayout *CodeGenTypes::ComputeRecordLayout(const RecordDecl *D) { if (BaseTy) { uint64_t AlignedNonVirtualTypeSizeInBits = - llvm::RoundUpToAlignment(Layout.getNonVirtualSize(), + llvm::RoundUpToAlignment(Layout.getNonVirtualSize().getQuantity() * 8, Layout.getNonVirtualAlign()); assert(AlignedNonVirtualTypeSizeInBits == |