aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/CGRecordLayoutBuilder.cpp
diff options
context:
space:
mode:
authorKen Dyck <kd@kendyck.com>2011-02-01 01:52:10 +0000
committerKen Dyck <kd@kendyck.com>2011-02-01 01:52:10 +0000
commit5c3633fa57f27b0909ab5767715c4e66b8920165 (patch)
tree5a2625537ff37e71fef7c6fbf5b8910f28eb4134 /lib/CodeGen/CGRecordLayoutBuilder.cpp
parent65e7a9e0597fdd68caa23d49991f3891e724e5c6 (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.cpp13
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 ==