diff options
author | Chris Lattner <sabre@nondot.org> | 2003-03-03 17:13:31 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2003-03-03 17:13:31 +0000 |
commit | 088b639e3a168686f16bb292e08b952d01a25b7d (patch) | |
tree | 0bc187f257c2f84051d80698c27b25e0aeae26ba /lib/Analysis/DataStructure/DataStructure.cpp | |
parent | af68ccefebc81752706fc9d2e0177c98f098463a (diff) |
Don't apply type information to load instructions if it will cause collapsing
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@5684 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/DataStructure/DataStructure.cpp')
-rw-r--r-- | lib/Analysis/DataStructure/DataStructure.cpp | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/lib/Analysis/DataStructure/DataStructure.cpp b/lib/Analysis/DataStructure/DataStructure.cpp index 27247897e5..1aad8cf69e 100644 --- a/lib/Analysis/DataStructure/DataStructure.cpp +++ b/lib/Analysis/DataStructure/DataStructure.cpp @@ -152,7 +152,8 @@ bool DSNode::isNodeCompletelyFolded() const { /// /// This method returns true if the node is completely folded, otherwise false. /// -bool DSNode::mergeTypeInfo(const Type *NewTy, unsigned Offset) { +bool DSNode::mergeTypeInfo(const Type *NewTy, unsigned Offset, + bool FoldIfIncompatible) { // Check to make sure the Size member is up-to-date. Size can be one of the // following: // Size = 0, Ty = Void: Nothing is known about this node. @@ -213,14 +214,14 @@ bool DSNode::mergeTypeInfo(const Type *NewTy, unsigned Offset) { // It is illegal to grow this node if we have treated it as an array of // objects... if (isArray()) { - foldNodeCompletely(); + if (FoldIfIncompatible) foldNodeCompletely(); return true; } if (Offset) { // We could handle this case, but we don't for now... DEBUG(std::cerr << "UNIMP: Trying to merge a growth type into " << "offset != 0: Collapsing!\n"); - foldNodeCompletely(); + if (FoldIfIncompatible) foldNodeCompletely(); return true; } @@ -277,7 +278,7 @@ bool DSNode::mergeTypeInfo(const Type *NewTy, unsigned Offset) { break; } default: - foldNodeCompletely(); + if (FoldIfIncompatible) foldNodeCompletely(); return true; } } @@ -356,7 +357,7 @@ bool DSNode::mergeTypeInfo(const Type *NewTy, unsigned Offset) { << "\n due to:" << NewTy << " @ " << Offset << "!\n" << "SubType: " << SubType << "\n\n"); - foldNodeCompletely(); + if (FoldIfIncompatible) foldNodeCompletely(); return true; } |