Fix some issues in WalkChainUsers dealing with
authorChris Lattner <sabre@nondot.org>
Tue, 2 Mar 2010 22:20:06 +0000 (22:20 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 2 Mar 2010 22:20:06 +0000 (22:20 +0000)
commitd1b738298359846b9cccaa0931e6ec1fc59a6d87
tree6611deab68a7063b6e19d30ee856bfe181cd82e9
parent10a77e14a0b41ebb1c0ee9c07b28550d96acd60c
Fix some issues in WalkChainUsers dealing with
CopyToReg/CopyFromReg/INLINEASM.  These are annoying because
they have the same opcode before an after isel.  Fix this by
setting their NodeID to -1 to indicate that they are selected,
just like what automatically happens when selecting things that
end up being machine nodes.

With that done, give IsLegalToFold a new flag that causes it to
ignore chains.  This lets the HandleMergeInputChains routine be
the one place that validates chains after a match is successful,
enabling the new hotness in chain processing.  This smarter
chain processing eliminates the need for "PreprocessRMW" in the
X86 and MSP430 backends and enables MSP to start matching it's
multiple mem operand instructions more aggressively.

I currently #if out the dead code in the X86 backend and MSP
backend, I'll remove it for real in a follow-on patch.

The testcase changes are:
  test/CodeGen/X86/sse3.ll: we generate better code
  test/CodeGen/X86/store_op_load_fold2.ll: PreprocessRMW was
      miscompiling this before, we now generate correct code
      Convert it to filecheck while I'm at it.
  test/CodeGen/MSP430/Inst16mm.ll: Add a testcase for mem/mem
      folding to make anton happy. :)

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@97596 91177308-0d34-0410-b5e6-96231b3b80d8
include/llvm/CodeGen/SelectionDAGISel.h
lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp
lib/Target/MSP430/MSP430ISelDAGToDAG.cpp
lib/Target/X86/X86ISelDAGToDAG.cpp
test/CodeGen/MSP430/Inst16mm.ll
test/CodeGen/X86/sse3.ll
test/CodeGen/X86/store_op_load_fold2.ll