summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2005-01-07 08:19:42 +0000
committerChris Lattner <sabre@nondot.org>2005-01-07 08:19:42 +0000
commitec3fe7c4a83c33d3ce0013b60e3b45d7683dd22d (patch)
tree83c1937fc71f543cce07d8475b446cc87d225f5f /llvm/lib/CodeGen
parent001467a08cd41600b3f88503579b12bb7061c800 (diff)
downloadbcm5719-llvm-ec3fe7c4a83c33d3ce0013b60e3b45d7683dd22d.tar.gz
bcm5719-llvm-ec3fe7c4a83c33d3ce0013b60e3b45d7683dd22d.zip
Teach legalize how to handle condbranches
llvm-svn: 19339
Diffstat (limited to 'llvm/lib/CodeGen')
-rw-r--r--llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp10
1 files changed, 10 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
index 748ad3f2879..c8369aa1c61 100644
--- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
@@ -305,6 +305,16 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
}
break;
+ case ISD::BRCOND:
+ Tmp1 = LegalizeOp(Node->getOperand(0)); // Legalize the chain.
+ // FIXME: booleans might not be legal!
+ Tmp2 = LegalizeOp(Node->getOperand(1)); // Legalize the condition.
+ // Basic block destination (Op#2) is always legal.
+ if (Tmp1 != Node->getOperand(0) || Tmp2 != Node->getOperand(1))
+ Result = DAG.getNode(ISD::BRCOND, MVT::Other, Tmp1, Tmp2,
+ Node->getOperand(2));
+ break;
+
case ISD::LOAD:
Tmp1 = LegalizeOp(Node->getOperand(0)); // Legalize the chain.
Tmp2 = LegalizeOp(Node->getOperand(1)); // Legalize the pointer.
OpenPOWER on IntegriCloud