diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-01-13 17:59:25 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-01-13 17:59:25 +0000 |
| commit | 05b4e37e85d5f761c57e0d02a4f28e6e13292984 (patch) | |
| tree | 5ca71ae23d0a3f31e35ef4b43260fb5ab5690ab7 /llvm/lib/CodeGen | |
| parent | 4b1be0dfeb1d6d1eb452876369b5d27476447c46 (diff) | |
| download | bcm5719-llvm-05b4e37e85d5f761c57e0d02a4f28e6e13292984.tar.gz bcm5719-llvm-05b4e37e85d5f761c57e0d02a4f28e6e13292984.zip | |
Legalize new node, add assertion.
llvm-svn: 19527
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 64c686efc67..58f98894efe 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -295,6 +295,18 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { } break; } + case ISD::TokenFactor: { + std::vector<SDOperand> Ops; + bool Changed = false; + for (unsigned i = 0, e = Node->getNumOperands(); i != e; ++i) { + Ops.push_back(LegalizeOp(Node->getOperand(i))); // Legalize the operands + Changed |= Ops[i] != Node->getOperand(i); + } + if (Changed) + Result = DAG.getNode(ISD::TokenFactor, MVT::Other, Ops); + break; + } + case ISD::ADJCALLSTACKDOWN: case ISD::ADJCALLSTACKUP: Tmp1 = LegalizeOp(Node->getOperand(0)); // Legalize the chain. @@ -662,6 +674,10 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { Result = DAG.getNode(Node->getOpcode(), Node->getValueType(0), Tmp1); break; case Expand: + assert(Node->getOpcode() != ISD::SINT_TO_FP && + Node->getOpcode() != ISD::UINT_TO_FP && + "Cannot lower Xint_to_fp to a call yet!"); + // In the expand case, we must be dealing with a truncate, because // otherwise the result would be larger than the source. assert(Node->getOpcode() == ISD::TRUNCATE && |

