summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CGCXX.cpp
diff options
context:
space:
mode:
authorAnders Carlsson <andersca@mac.com>2009-12-05 18:38:15 +0000
committerAnders Carlsson <andersca@mac.com>2009-12-05 18:38:15 +0000
commit5a1a84f9fa772bf0772c2d3b3b05945e3ebb5526 (patch)
tree4d3ac84e0b384249287dc22a694e0d5ada809e65 /clang/lib/CodeGen/CGCXX.cpp
parent35f5646ef067d45148456c61e5e5b526c43fc2db (diff)
downloadbcm5719-llvm-5a1a84f9fa772bf0772c2d3b3b05945e3ebb5526.tar.gz
bcm5719-llvm-5a1a84f9fa772bf0772c2d3b3b05945e3ebb5526.zip
Simplify some code.
llvm-svn: 90670
Diffstat (limited to 'clang/lib/CodeGen/CGCXX.cpp')
-rw-r--r--clang/lib/CodeGen/CGCXX.cpp22
1 files changed, 11 insertions, 11 deletions
diff --git a/clang/lib/CodeGen/CGCXX.cpp b/clang/lib/CodeGen/CGCXX.cpp
index 6d96124a384..c536350ad4b 100644
--- a/clang/lib/CodeGen/CGCXX.cpp
+++ b/clang/lib/CodeGen/CGCXX.cpp
@@ -1702,18 +1702,18 @@ void CodeGenFunction::EmitCtorPrologue(const CXXConstructorDecl *CD,
PopCXXTemporary();
}
+ if (!ClassDecl->isDynamicClass())
+ return;
+
// Initialize the vtable pointer
- if (ClassDecl->isDynamicClass()) {
- if (!LoadOfThis)
- LoadOfThis = LoadCXXThis();
- llvm::Value *VtableField;
- llvm::Type *Ptr8Ty, *PtrPtr8Ty;
- Ptr8Ty = llvm::PointerType::get(llvm::Type::getInt8Ty(VMContext), 0);
- PtrPtr8Ty = llvm::PointerType::get(Ptr8Ty, 0);
- VtableField = Builder.CreateBitCast(LoadOfThis, PtrPtr8Ty);
- llvm::Value *vtable = CGM.getVtableInfo().getVtable(ClassDecl);
- Builder.CreateStore(vtable, VtableField);
- }
+ if (!LoadOfThis)
+ LoadOfThis = LoadCXXThis();
+
+ const llvm::Type *Int8PtrTy = llvm::Type::getInt8PtrTy(VMContext);
+ llvm::Value *VtableField =
+ Builder.CreateBitCast(LoadOfThis, Int8PtrTy->getPointerTo());
+ llvm::Value *vtable = CGM.getVtableInfo().getVtable(ClassDecl);
+ Builder.CreateStore(vtable, VtableField);
}
/// EmitDtorEpilogue - Emit all code that comes at the end of class's
OpenPOWER on IntegriCloud