diff options
author | Owen Anderson <resistor@mac.com> | 2011-06-21 22:54:23 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2011-06-21 22:54:23 +0000 |
commit | d1955e78b4d5f2d6c592d10046bf9d23f804b304 (patch) | |
tree | 6def1cad1afb941313874d99aa71ffd3a4864eae /llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp | |
parent | ef9c497e4c0012ca7a1a4229d7ebed7d54c3df73 (diff) | |
download | bcm5719-llvm-d1955e78b4d5f2d6c592d10046bf9d23f804b304.tar.gz bcm5719-llvm-d1955e78b4d5f2d6c592d10046bf9d23f804b304.zip |
Fix some trailing issues from my introduction of MVT::untyped and its use for REGISTER_SEQUENCE.
llvm-svn: 133567
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp index 64faeb4c27e..a827187e357 100644 --- a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAGRRList.cpp @@ -290,7 +290,17 @@ static void GetCostForDef(const ScheduleDAGSDNodes::RegDefIter &RegDefPos, // Special handling for untyped values. These values can only come from // the expansion of custom DAG-to-DAG patterns. if (VT == MVT::untyped) { - unsigned Opcode = RegDefPos.GetNode()->getMachineOpcode(); + const SDNode *Node = RegDefPos.GetNode(); + unsigned Opcode = Node->getMachineOpcode(); + + if (Opcode == TargetOpcode::REG_SEQUENCE) { + unsigned DstRCIdx = cast<ConstantSDNode>(Node->getOperand(0))->getZExtValue(); + const TargetRegisterClass *RC = TRI->getRegClass(DstRCIdx); + RegClass = RC->getID(); + Cost = 1; + return; + } + unsigned Idx = RegDefPos.GetIdx(); const TargetInstrDesc Desc = TII->get(Opcode); const TargetRegisterClass *RC = Desc.getRegClass(Idx, TRI); |