diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-06-11 19:14:25 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-06-11 19:14:25 +0000 |
commit | 4a28f534e178edd6a0fd7427751e82a5e831b4dd (patch) | |
tree | 6f7b0509de80db0933df481dd0525f2bf6eba4dc /clang/lib/CodeGen/CGCleanup.cpp | |
parent | 75f89f522548d6a81cec3d9e00633e8be8ad7373 (diff) | |
download | bcm5719-llvm-4a28f534e178edd6a0fd7427751e82a5e831b4dd.tar.gz bcm5719-llvm-4a28f534e178edd6a0fd7427751e82a5e831b4dd.zip |
Revert r183721. It caused cleanups to be delayed too long in some cases.
Testcase to follow.
llvm-svn: 183776
Diffstat (limited to 'clang/lib/CodeGen/CGCleanup.cpp')
-rw-r--r-- | clang/lib/CodeGen/CGCleanup.cpp | 27 |
1 files changed, 0 insertions, 27 deletions
diff --git a/clang/lib/CodeGen/CGCleanup.cpp b/clang/lib/CodeGen/CGCleanup.cpp index 65de4d498d1..9f693ca8b7b 100644 --- a/clang/lib/CodeGen/CGCleanup.cpp +++ b/clang/lib/CodeGen/CGCleanup.cpp @@ -387,33 +387,6 @@ void CodeGenFunction::PopCleanupBlocks(EHScopeStack::stable_iterator Old) { } } -/// Pops cleanup blocks until the given savepoint is reached, then add the -/// cleanups from the given savepoint in the lifetime-extended cleanups stack. -void -CodeGenFunction::PopCleanupBlocks(EHScopeStack::stable_iterator Old, - size_t OldLifetimeExtendedSize) { - PopCleanupBlocks(Old); - - // Move our deferred cleanups onto the EH stack. - for (size_t I = OldLifetimeExtendedSize, - E = LifetimeExtendedCleanupStack.size(); I != E; /**/) { - // Alignment should be guaranteed by the vptrs in the individual cleanups. - assert((I % llvm::alignOf<LifetimeExtendedCleanupHeader>() == 0) && - "misaligned cleanup stack entry"); - - LifetimeExtendedCleanupHeader &Header = - reinterpret_cast<LifetimeExtendedCleanupHeader&>( - LifetimeExtendedCleanupStack[I]); - I += sizeof(Header); - - EHStack.pushCopyOfCleanup(Header.getKind(), - &LifetimeExtendedCleanupStack[I], - Header.getSize()); - I += Header.getSize(); - } - LifetimeExtendedCleanupStack.resize(OldLifetimeExtendedSize); -} - static llvm::BasicBlock *CreateNormalEntry(CodeGenFunction &CGF, EHCleanupScope &Scope) { assert(Scope.isNormalCleanup()); |