diff options
author | Chris Lattner <sabre@nondot.org> | 2008-11-29 23:30:39 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-11-29 23:30:39 +0000 |
commit | 4f8c18c7c757875cfa45383e7cf33d65d2c4d564 (patch) | |
tree | b3fdaa7ff61c94ae583d5a92f25302521dd96079 /lib/Transforms/Scalar/MemCpyOptimizer.cpp | |
parent | 4fd40e884c76ffbf1157ab4ca48a099c55eebb4f (diff) |
Eliminate the dropInstruction method, which is not needed any more.
Fix a subtle iterator invalidation bug I introduced in the last commit.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@60258 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/Scalar/MemCpyOptimizer.cpp')
-rw-r--r-- | lib/Transforms/Scalar/MemCpyOptimizer.cpp | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/lib/Transforms/Scalar/MemCpyOptimizer.cpp b/lib/Transforms/Scalar/MemCpyOptimizer.cpp index 40eaa1d47c..5d68388a99 100644 --- a/lib/Transforms/Scalar/MemCpyOptimizer.cpp +++ b/lib/Transforms/Scalar/MemCpyOptimizer.cpp @@ -609,7 +609,7 @@ bool MemCpyOpt::performCallSlotOptzn(MemCpyInst *cpy, CallInst *C) { // Drop any cached information about the call, because we may have changed // its dependence information by changing its parameter. MemoryDependenceAnalysis& MD = getAnalysis<MemoryDependenceAnalysis>(); - MD.dropInstruction(C); + MD.removeInstruction(C); // Remove the memcpy MD.removeInstruction(cpy); @@ -691,11 +691,9 @@ bool MemCpyOpt::processMemCpy(MemCpyInst* M) { // If C and M don't interfere, then this is a valid transformation. If they // did, this would mean that the two sources overlap, which would be bad. if (MD.getDependency(C) == dep) { - MD.dropInstruction(M); + MD.removeInstruction(M); M->eraseFromParent(); - NumMemCpyInstr++; - return true; } @@ -703,7 +701,6 @@ bool MemCpyOpt::processMemCpy(MemCpyInst* M) { // inserted and act like nothing happened. MD.removeInstruction(C); C->eraseFromParent(); - return false; } |