forked from OSchip/llvm-project
Don't create a new node for every reference to a global. This caused a huge
node explosion that doesn't help anything at all. In previous versions of the representation this DID help, but not anymore. llvm-svn: 4249
This commit is contained in:
parent
800b7e33df
commit
32438d8c84
|
@ -186,12 +186,9 @@ DSNodeHandle &GraphBuilder::getGlobalNode(GlobalValue &V) {
|
||||||
//
|
//
|
||||||
DSNodeHandle GraphBuilder::getValueNode(Value &V) {
|
DSNodeHandle GraphBuilder::getValueNode(Value &V) {
|
||||||
assert(isPointerType(V.getType()) && "Should only use pointer scalars!");
|
assert(isPointerType(V.getType()) && "Should only use pointer scalars!");
|
||||||
// Do not share the pointer value to globals... this would cause way too much
|
|
||||||
// false merging.
|
|
||||||
//
|
|
||||||
DSNodeHandle &NH = ValueMap[&V];
|
DSNodeHandle &NH = ValueMap[&V];
|
||||||
if (!isa<GlobalValue>(V) && NH.getNode())
|
if (NH.getNode()) return NH; // Already have a node? Just return it...
|
||||||
return NH; // Already have a node? Just return it...
|
|
||||||
|
|
||||||
// Otherwise we need to create a new scalar node...
|
// Otherwise we need to create a new scalar node...
|
||||||
DSNode *N = createNode(DSNode::ScalarNode, V.getType());
|
DSNode *N = createNode(DSNode::ScalarNode, V.getType());
|
||||||
|
|
Loading…
Reference in New Issue