mirror of
https://github.com/RPCS3/llvm.git
synced 2025-04-17 13:30:41 +00:00
Switch DIDescriptor to use a TrackingVH. - This makes it much safer to work with debug info, since it was extraordinarily easy to have dangling pointers thanks to MDNode uniquing.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@82507 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e5b18362db
commit
48a097bfb6
@ -24,6 +24,7 @@
|
|||||||
#include "llvm/ADT/SmallVector.h"
|
#include "llvm/ADT/SmallVector.h"
|
||||||
#include "llvm/ADT/SmallPtrSet.h"
|
#include "llvm/ADT/SmallPtrSet.h"
|
||||||
#include "llvm/Support/Dwarf.h"
|
#include "llvm/Support/Dwarf.h"
|
||||||
|
#include "llvm/Support/ValueHandle.h"
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
class BasicBlock;
|
class BasicBlock;
|
||||||
@ -45,7 +46,7 @@ namespace llvm {
|
|||||||
|
|
||||||
class DIDescriptor {
|
class DIDescriptor {
|
||||||
protected:
|
protected:
|
||||||
MDNode *DbgNode;
|
TrackingVH<MDNode> DbgNode;
|
||||||
|
|
||||||
/// DIDescriptor constructor. If the specified node is non-null, check
|
/// DIDescriptor constructor. If the specified node is non-null, check
|
||||||
/// to make sure that the tag in the descriptor matches 'RequiredTag'. If
|
/// to make sure that the tag in the descriptor matches 'RequiredTag'. If
|
||||||
|
@ -267,8 +267,17 @@ void DIDerivedType::replaceAllUsesWith(DIDescriptor &D) {
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
assert (!D.isNull() && "Can not replace with null");
|
assert (!D.isNull() && "Can not replace with null");
|
||||||
DbgNode->replaceAllUsesWith(D.getNode());
|
|
||||||
delete DbgNode;
|
// Since we use a TrackingVH for the node, its easy for clients to manufacture
|
||||||
|
// legitimate situations where they want to replaceAllUsesWith() on something
|
||||||
|
// which, due to uniquing, has merged with the source. We shield clients from
|
||||||
|
// this detail by allowing a value to be replaced with replaceAllUsesWith()
|
||||||
|
// itself.
|
||||||
|
if (getNode() != D.getNode()) {
|
||||||
|
MDNode *Node = DbgNode;
|
||||||
|
Node->replaceAllUsesWith(D.getNode());
|
||||||
|
delete Node;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Verify - Verify that a compile unit is well formed.
|
/// Verify - Verify that a compile unit is well formed.
|
||||||
@ -395,7 +404,7 @@ bool DISubprogram::describes(const Function *F) {
|
|||||||
/// dump - Print descriptor.
|
/// dump - Print descriptor.
|
||||||
void DIDescriptor::dump() const {
|
void DIDescriptor::dump() const {
|
||||||
errs() << "[" << dwarf::TagString(getTag()) << "] ";
|
errs() << "[" << dwarf::TagString(getTag()) << "] ";
|
||||||
errs().write_hex((intptr_t)DbgNode) << ']';
|
errs().write_hex((intptr_t) &*DbgNode) << ']';
|
||||||
}
|
}
|
||||||
|
|
||||||
/// dump - Print compile unit.
|
/// dump - Print compile unit.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user