diff options
author | Mike Stump <mrs@apple.com> | 2009-11-13 23:13:20 +0000 |
---|---|---|
committer | Mike Stump <mrs@apple.com> | 2009-11-13 23:13:20 +0000 |
commit | 559387fe8b742ee4f5379e0a0f968f6921c70ec7 (patch) | |
tree | 9056a661256479f9c0c62c41dc31f82ec60054d0 | |
parent | 96b26acd0f662720834e6a98aa1e62ec2a28bf5b (diff) | |
download | bcm5719-llvm-559387fe8b742ee4f5379e0a0f968f6921c70ec7.tar.gz bcm5719-llvm-559387fe8b742ee4f5379e0a0f968f6921c70ec7.zip |
Also track address points for primaries bases.
llvm-svn: 88717
-rw-r--r-- | clang/lib/CodeGen/CGVtable.cpp | 31 |
1 files changed, 27 insertions, 4 deletions
diff --git a/clang/lib/CodeGen/CGVtable.cpp b/clang/lib/CodeGen/CGVtable.cpp index 0de8430c726..bbe6ca13746 100644 --- a/clang/lib/CodeGen/CGVtable.cpp +++ b/clang/lib/CodeGen/CGVtable.cpp @@ -490,6 +490,32 @@ public: VCall.clear(); } + void AddAddressPoints(const CXXRecordDecl *RD, uint64_t Offset, + Index_t AddressPoint) { + D1(printf("XXX address point for %s in %s layout %s at offset %d is %d\n", + RD->getNameAsCString(), Class->getNameAsCString(), + LayoutClass->getNameAsCString(), (int)Offset, (int)AddressPoint)); + AddressPoints[std::make_pair(RD, Offset)] = AddressPoint; + + // Now also add the address point for all our primary bases. + while (1) { + const ASTRecordLayout &Layout = CGM.getContext().getASTRecordLayout(RD); + RD = Layout.getPrimaryBase(); + const bool PrimaryBaseWasVirtual = Layout.getPrimaryBaseWasVirtual(); + // FIXME: Double check this. + if (RD == 0) + break; + if (PrimaryBaseWasVirtual && + BLayout.getVBaseClassOffset(RD) != Offset) + break; + D1(printf("XXX address point for %s in %s layout %s at offset %d is %d\n", + RD->getNameAsCString(), Class->getNameAsCString(), + LayoutClass->getNameAsCString(), (int)Offset, (int)AddressPoint)); + AddressPoints[std::make_pair(RD, Offset)] = AddressPoint; + } + } + + Index_t end(const CXXRecordDecl *RD, const ASTRecordLayout &Layout, const CXXRecordDecl *PrimaryBase, bool PrimaryBaseWasVirtual, bool MorallyVirtual, int64_t Offset, bool ForVirtualBase, @@ -536,10 +562,7 @@ public: insertVCalls(VCallInsertionPoint); } - D1(printf("XXX address point for %s in %s layout %s at offset %d is %d\n", - RD->getNameAsCString(), Class->getNameAsCString(), - LayoutClass->getNameAsCString(), (int)Offset, (int)AddressPoint)); - AddressPoints[std::make_pair(RD, Offset)] = AddressPoint; + AddAddressPoints(RD, Offset, AddressPoint); if (alloc) { delete Path; |