summaryrefslogtreecommitdiffstats
path: root/clang/lib/CodeGen/CGCleanup.cpp
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2013-06-11 19:14:25 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2013-06-11 19:14:25 +0000
commit4a28f534e178edd6a0fd7427751e82a5e831b4dd (patch)
tree6f7b0509de80db0933df481dd0525f2bf6eba4dc /clang/lib/CodeGen/CGCleanup.cpp
parent75f89f522548d6a81cec3d9e00633e8be8ad7373 (diff)
downloadbcm5719-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.cpp27
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());
OpenPOWER on IntegriCloud