summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFrederic Riss <friss@apple.com>2014-09-15 07:50:42 +0000
committerFrederic Riss <friss@apple.com>2014-09-15 07:50:42 +0000
commitdd7aec5ddec1881c1d9c7ba7b26e1bc3abe19746 (patch)
treee83a38032aad071d20e4742ca7ef228585fdcd54
parent36acf0fb8b8627bd586fe7df8872b1c8a17ab7cd (diff)
downloadbcm5719-llvm-dd7aec5ddec1881c1d9c7ba7b26e1bc3abe19746.tar.gz
bcm5719-llvm-dd7aec5ddec1881c1d9c7ba7b26e1bc3abe19746.zip
Fix DebugInfo replaceAllUsesWith.
Summary: replaceAllUsesWith had been modified to allow a DbgNode value to be replaced by itself. In that case a new node is created by copying the current DbgNode and the copy is used as replacement value. When that copying happens, the value stored in this->DbgNode at the end of RAUW would be a reference to the Node that has just been deleted. This doesn't produce any bug right now, because the DI node on which we call RAUW won't be used again. Reviewers: dblaikie, echristo, aprantl Subscribers: llvm-commits Differential Revision: http://reviews.llvm.org/D5326 llvm-svn: 217749
-rw-r--r--llvm/lib/IR/DebugInfo.cpp2
1 files changed, 1 insertions, 1 deletions
diff --git a/llvm/lib/IR/DebugInfo.cpp b/llvm/lib/IR/DebugInfo.cpp
index 71c32fc969d..4274d82d158 100644
--- a/llvm/lib/IR/DebugInfo.cpp
+++ b/llvm/lib/IR/DebugInfo.cpp
@@ -384,7 +384,7 @@ void DIDescriptor::replaceAllUsesWith(LLVMContext &VMContext, DIDescriptor D) {
const Value *V = cast_or_null<Value>(DN);
Node->replaceAllUsesWith(const_cast<Value *>(V));
MDNode::deleteTemporary(Node);
- DbgNode = D;
+ DbgNode = DN;
}
/// replaceAllUsesWith - Replace all uses of the MDNode used by this
OpenPOWER on IntegriCloud