Do not force asm's to be chained if they don't touch
authorDale Johannesen <dalej@apple.com>
Tue, 14 Apr 2009 00:56:56 +0000 (00:56 +0000)
committerDale Johannesen <dalej@apple.com>
Tue, 14 Apr 2009 00:56:56 +0000 (00:56 +0000)
memory and aren't volatile.  This was interfering with
good scheduling.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@69008 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/SelectionDAGBuild.cpp

index 0fc5cb13cf4077744fd72b531ea03873effaaaee..96fae4d3eec05af9342808d115ac9761d228cfec 100644 (file)
@@ -5439,6 +5439,9 @@ void SelectionDAGLowering::visitInlineAsm(CallSite CS) {
     }
 
     setValue(CS.getInstruction(), Val);
+    // Don't need to use this as a chain in this case.
+    if (!IA->hasSideEffects() && !hasMemory && IndirectStoresToEmit.empty())
+      return;
   }
 
   std::vector<std::pair<SDValue, Value*> > StoresToEmit;