diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2009-12-04 04:30:03 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2009-12-04 04:30:03 +0000 |
commit | 94bc2dade6737fb7738d6fe1267797f66f8ce8e6 (patch) | |
tree | 16da1c37d109ac25684fd528f465058b253f1ab2 /clang/lib/CodeGen/CGVtable.cpp | |
parent | 6d947a0774fc58bc49519edd7548fe147519843f (diff) | |
download | bcm5719-llvm-94bc2dade6737fb7738d6fe1267797f66f8ce8e6.tar.gz bcm5719-llvm-94bc2dade6737fb7738d6fe1267797f66f8ce8e6.zip |
Fix regression in vtable improvements.
llvm-svn: 90540
Diffstat (limited to 'clang/lib/CodeGen/CGVtable.cpp')
-rw-r--r-- | clang/lib/CodeGen/CGVtable.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CGVtable.cpp b/clang/lib/CodeGen/CGVtable.cpp index 869bcc0e6a6..5e448273729 100644 --- a/clang/lib/CodeGen/CGVtable.cpp +++ b/clang/lib/CodeGen/CGVtable.cpp @@ -742,7 +742,7 @@ bool VtableBuilder::OverrideMethod(GlobalDecl GD, llvm::Constant *m, mi != e; ++mi) { GlobalDecl OGD; - const CXXMethodDecl *OMD = *mi; + const CXXMethodDecl *OMD = (*mi)->getCanonicalDecl(); if (const CXXDestructorDecl *DD = dyn_cast<CXXDestructorDecl>(OMD)) OGD = GlobalDecl(DD, GD.getDtorType()); else @@ -933,7 +933,7 @@ void CGVtableInfo::ComputeMethodVtableIndices(const CXXRecordDecl *RD) { // Check if this method overrides a method in the primary base. for (CXXMethodDecl::method_iterator i = MD->begin_overridden_methods(), e = MD->end_overridden_methods(); i != e; ++i) { - const CXXMethodDecl *OverriddenMD = *i; + const CXXMethodDecl *OverriddenMD = (*i)->getCanonicalDecl(); const CXXRecordDecl *OverriddenRD = OverriddenMD->getParent(); assert(OverriddenMD->isCanonicalDecl() && "Should have the canonical decl of the overridden RD!"); |