From: Bob Wilson Date: Sun, 25 Jul 2010 05:34:27 +0000 (+0000) Subject: Fix crashes when scheduling a CopyToReg node -- getMachineOpcode asserts on X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=3f92f73970862c1926b4c70fe097c979de5f02d0;p=oota-llvm.git Fix crashes when scheduling a CopyToReg node -- getMachineOpcode asserts on those. Radar 8231572. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@109367 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp b/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp index b5e4ad9cdee..25e5b0ee4c0 100644 --- a/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp +++ b/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp @@ -1313,7 +1313,7 @@ namespace { } } - if (SU->NumSuccs) { + if (SU->NumSuccs && N->getOpcode() != ISD::CopyToReg) { unsigned NumDefs = TII->get(N->getMachineOpcode()).getNumDefs(); for (unsigned i = 0; i != NumDefs; ++i) { EVT VT = N->getValueType(i); @@ -1394,7 +1394,7 @@ namespace { } } - if (SU->NumSuccs) { + if (SU->NumSuccs && N->getOpcode() != ISD::CopyToReg) { unsigned NumDefs = TII->get(N->getMachineOpcode()).getNumDefs(); for (unsigned i = NumDefs, e = N->getNumValues(); i != e; ++i) { EVT VT = N->getValueType(i);