diff options
author | Anders Carlsson <andersca@mac.com> | 2009-12-05 18:38:15 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-12-05 18:38:15 +0000 |
commit | 5a1a84f9fa772bf0772c2d3b3b05945e3ebb5526 (patch) | |
tree | 4d3ac84e0b384249287dc22a694e0d5ada809e65 /clang/lib/CodeGen/CGCXX.cpp | |
parent | 35f5646ef067d45148456c61e5e5b526c43fc2db (diff) | |
download | bcm5719-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.cpp | 22 |
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 |