mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-05 17:39:16 +00:00
Clear the SCEVExpander's insertion point after making deletions,
so that the SCEVExpander doesn't retain a dangling pointer as its insert position. The dangling pointer in this case wasn't ever used to insert new instructions, but it was causing trouble with SCEVExpander's code for automatically advancing its insert position past debug intrinsics. This fixes use-after-free errors that valgrind noticed in test/Transforms/IndVarSimplify/2007-06-06-DeleteDanglesPtr.ll and test/Transforms/IndVarSimplify/exit_value_tests.ll. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@99036 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
1ad584e93d
commit
472fdf7090
@ -104,6 +104,13 @@ namespace llvm {
|
||||
/// is useful for late optimization passes.
|
||||
void disableCanonicalMode() { CanonicalMode = false; }
|
||||
|
||||
/// clearInsertPoint - Clear the current insertion point. This is useful
|
||||
/// if the instruction that had been serving as the insertion point may
|
||||
/// have been deleted.
|
||||
void clearInsertPoint() {
|
||||
Builder.ClearInsertionPoint();
|
||||
}
|
||||
|
||||
private:
|
||||
LLVMContext &getContext() const { return SE.getContext(); }
|
||||
|
||||
|
@ -307,6 +307,10 @@ void IndVarSimplify::RewriteLoopExitValues(Loop *L,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// The insertion point instruction may have been deleted; clear it out
|
||||
// so that the rewriter doesn't trip over it later.
|
||||
Rewriter.clearInsertPoint();
|
||||
}
|
||||
|
||||
void IndVarSimplify::RewriteNonIntegerIVs(Loop *L) {
|
||||
|
Loading…
x
Reference in New Issue
Block a user