From dbfc4e4b07fa1760e00be3437ef916e56b38f419 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sat, 25 Aug 2007 00:53:07 +0000 Subject: Teach the dag scheduler to handle inline asm nodes with multi-value immediate operands. llvm-svn: 41386 --- llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp | 17 +++++++++-------- 1 file changed, 9 insertions(+), 8 deletions(-) (limited to 'llvm') diff --git a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp index 192b0767e36..11c69a4e293 100644 --- a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp @@ -753,15 +753,16 @@ void ScheduleDAG::EmitNode(SDNode *Node, } break; case 3: { // Immediate. - assert(NumVals == 1 && "Unknown immediate value!"); - if (ConstantSDNode *CS=dyn_cast(Node->getOperand(i))){ - MI->addImmOperand(CS->getValue()); - } else { - GlobalAddressSDNode *GA = - cast(Node->getOperand(i)); - MI->addGlobalAddressOperand(GA->getGlobal(), GA->getOffset()); + for (; NumVals; --NumVals, ++i) { + if (ConstantSDNode *CS = + dyn_cast(Node->getOperand(i))) { + MI->addImmOperand(CS->getValue()); + } else { + GlobalAddressSDNode *GA = + cast(Node->getOperand(i)); + MI->addGlobalAddressOperand(GA->getGlobal(), GA->getOffset()); + } } - ++i; break; } case 4: // Addressing mode. -- cgit v1.2.3