diff options
| author | Anders Carlsson <andersca@mac.com> | 2010-05-05 05:47:36 +0000 |
|---|---|---|
| committer | Anders Carlsson <andersca@mac.com> | 2010-05-05 05:47:36 +0000 |
| commit | 58fe1756fb11ee441561cad8ea2acbe7888be913 (patch) | |
| tree | 9b719aff3b5baea3a3df56aa14958aed72d54f60 /clang/lib/CodeGen | |
| parent | ecc60b99f9465ffcee77d89eae705957b0aa3549 (diff) | |
| download | bcm5719-llvm-58fe1756fb11ee441561cad8ea2acbe7888be913.tar.gz bcm5719-llvm-58fe1756fb11ee441561cad8ea2acbe7888be913.zip | |
Use a more appropriate LLVM type for the vtable pointer.
llvm-svn: 103078
Diffstat (limited to 'clang/lib/CodeGen')
| -rw-r--r-- | clang/lib/CodeGen/CGRecordLayoutBuilder.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp b/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp index 6302cf8d1fc..0966678f3e6 100644 --- a/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp +++ b/clang/lib/CodeGen/CGRecordLayoutBuilder.cpp @@ -439,12 +439,14 @@ void CGRecordLayoutBuilder::LayoutBases(const CXXRecordDecl *RD, const ASTRecordLayout &Layout) { // Check if we need to add a vtable pointer. if (RD->isDynamicClass() && !Layout.getPrimaryBase()) { - const llvm::Type *Int8PtrTy = - llvm::Type::getInt8PtrTy(Types.getLLVMContext()); + const llvm::Type *FunctionType = + llvm::FunctionType::get(llvm::Type::getInt32Ty(Types.getLLVMContext()), + /*isVarArg=*/true); + const llvm::Type *VTableTy = FunctionType->getPointerTo(); assert(NextFieldOffsetInBytes == 0 && "VTable pointer must come first!"); - AppendField(NextFieldOffsetInBytes, Int8PtrTy->getPointerTo()); + AppendField(NextFieldOffsetInBytes, VTableTy->getPointerTo()); } } |

