diff options
author | Dale Johannesen <dalej@apple.com> | 2007-11-05 21:20:28 +0000 |
---|---|---|
committer | Dale Johannesen <dalej@apple.com> | 2007-11-05 21:20:28 +0000 |
commit | 4646aa3e337aa16f53d651e4b5e60fb46f2d182f (patch) | |
tree | 3fffcf48a8c4b62f8fccc389b31d5be5e1e5cdc8 /llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp | |
parent | 58473ab478e030657f859740710663ec4d2b341b (diff) | |
download | bcm5719-llvm-4646aa3e337aa16f53d651e4b5e60fb46f2d182f.tar.gz bcm5719-llvm-4646aa3e337aa16f53d651e4b5e60fb46f2d182f.zip |
Make labels work in asm blocks; allow labels as
parameters. Rename ValueRefList to ParamList
in AsmParser, since its only use is for parameters.
llvm-svn: 43734
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp index c98c1312fd6..ec84b705bbf 100644 --- a/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/ScheduleDAG.cpp @@ -803,10 +803,13 @@ void ScheduleDAG::EmitNode(SDNode *Node, unsigned InstanceNo, if (ConstantSDNode *CS = dyn_cast<ConstantSDNode>(Node->getOperand(i))) { MI->addImmOperand(CS->getValue()); - } else { - GlobalAddressSDNode *GA = - cast<GlobalAddressSDNode>(Node->getOperand(i)); + } else if (GlobalAddressSDNode *GA = + dyn_cast<GlobalAddressSDNode>(Node->getOperand(i))) { MI->addGlobalAddressOperand(GA->getGlobal(), GA->getOffset()); + } else { + BasicBlockSDNode *BB = + cast<BasicBlockSDNode>(Node->getOperand(i)); + MI->addMachineBasicBlockOperand(BB->getBasicBlock()); } } break; |