Make sure the two arguments of a setcc instruction point to the same node.
authorChris Lattner <sabre@nondot.org>
Sat, 5 Mar 2005 19:04:31 +0000 (19:04 +0000)
committerChris Lattner <sabre@nondot.org>
Sat, 5 Mar 2005 19:04:31 +0000 (19:04 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@20462 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Analysis/DataStructure/Local.cpp

index 070b695b34c31fc3166c1ba482c519c607945750..20f45a7b27d44c003592ff00e50b977d307e6a32 100644 (file)
@@ -112,7 +112,7 @@ namespace {
     void visitStoreInst(StoreInst &SI);
     void visitCallInst(CallInst &CI);
     void visitInvokeInst(InvokeInst &II);
-    void visitSetCondInst(SetCondInst &SCI) {}  // SetEQ & friends are ignored
+    void visitSetCondInst(SetCondInst &SCI);
     void visitFreeInst(FreeInst &FI);
     void visitCastInst(CastInst &CI);
     void visitInstruction(Instruction &I);
@@ -325,6 +325,13 @@ void GraphBuilder::visitSelectInst(SelectInst &SI) {
   Dest.mergeWith(getValueDest(*SI.getOperand(2)));
 }
 
+void GraphBuilder::visitSetCondInst(SetCondInst &SCI) {
+  if (!isPointerType(SCI.getOperand(0)->getType()) ||
+      isa<ConstantPointerNull>(SCI.getOperand(1))) return; // Only pointers
+  ScalarMap[SCI.getOperand(0)].mergeWith(getValueDest(*SCI.getOperand(1)));
+}
+
+
 void GraphBuilder::visitGetElementPtrInst(User &GEP) {
   DSNodeHandle Value = getValueDest(*GEP.getOperand(0));
   if (Value.isNull())