diff options
| author | Chris Lattner <sabre@nondot.org> | 2005-09-02 01:15:01 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2005-09-02 01:15:01 +0000 |
| commit | d9af1aab517ac7104e033bddceb4f12b6dacf8a6 (patch) | |
| tree | d9973d0c88a898593af8f26ad1125b087315647e /llvm/lib/CodeGen | |
| parent | 06d440f2eefb08c51fdbc9e4b6b6be7bfebd449f (diff) | |
| download | bcm5719-llvm-d9af1aab517ac7104e033bddceb4f12b6dacf8a6.tar.gz bcm5719-llvm-d9af1aab517ac7104e033bddceb4f12b6dacf8a6.zip | |
Make sure to legalize assert[zs]ext's operand correctly
llvm-svn: 23208
Diffstat (limited to 'llvm/lib/CodeGen')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 235fe0f3efe..461104c1f58 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -456,14 +456,19 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { assert(0 && "Do not know how to legalize this operator!"); abort(); case ISD::EntryToken: - case ISD::AssertSext: - case ISD::AssertZext: case ISD::FrameIndex: case ISD::GlobalAddress: case ISD::ExternalSymbol: case ISD::ConstantPool: // Nothing to do. assert(isTypeLegal(Node->getValueType(0)) && "This must be legal!"); break; + case ISD::AssertSext: + case ISD::AssertZext: + Tmp1 = LegalizeOp(Node->getOperand(0)); + if (Tmp1 != Node->getOperand(0)) + Result = DAG.getNode(Node->getOpcode(), Node->getValueType(0), Tmp1, + Node->getOperand(1)); + break; case ISD::CopyFromReg: Tmp1 = LegalizeOp(Node->getOperand(0)); if (Tmp1 != Node->getOperand(0)) |

