summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2005-12-19 23:12:38 +0000
committerEvan Cheng <evan.cheng@apple.com>2005-12-19 23:12:38 +0000
commit6fc31046aa16da16a1b4c05f48ebc89ab3b4c39d (patch)
tree27ff1cf15789de03b98337a38c299c4dd94c12ed /llvm/lib/CodeGen
parent9fd95413670ca3ad45245453406ec3480fe9c73a (diff)
downloadbcm5719-llvm-6fc31046aa16da16a1b4c05f48ebc89ab3b4c39d.tar.gz
bcm5719-llvm-6fc31046aa16da16a1b4c05f48ebc89ab3b4c39d.zip
X86 conditional branch support.
llvm-svn: 24870
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 d575ee617f3..bdc49513eba 100644
--- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp
@@ -883,6 +883,16 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
}
Result = LegalizeOp(Result); // Relegalize new nodes.
break;
+ case TargetLowering::Custom: {
+ SDOperand Tmp =
+ TLI.LowerOperation(DAG.getNode(ISD::BRCOND, Node->getValueType(0),
+ Tmp1, Tmp2, Node->getOperand(2)), DAG);
+ if (Tmp.Val) {
+ Result = LegalizeOp(Tmp);
+ break;
+ }
+ // FALLTHROUGH if the target thinks it is legal.
+ }
case TargetLowering::Legal:
// Basic block destination (Op#2) is always legal.
if (Tmp1 != Node->getOperand(0) || Tmp2 != Node->getOperand(1))
OpenPOWER on IntegriCloud