diff options
author | Dan Gohman <gohman@apple.com> | 2010-06-24 17:08:31 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2010-06-24 17:08:31 +0000 |
commit | 8a84cd57ae9e797cf6fd88415a19ad543fdc0b39 (patch) | |
tree | f20862845fa24d72b4aeae949b2d455a013a3b2a /llvm/lib | |
parent | 963b1c142eee1e4b4fc5438eb643c8edd2a67446 (diff) | |
download | bcm5719-llvm-8a84cd57ae9e797cf6fd88415a19ad543fdc0b39.tar.gz bcm5719-llvm-8a84cd57ae9e797cf6fd88415a19ad543fdc0b39.zip |
Simplify this code; switch lowering shouldn't produce cases
which trivially fold away.
llvm-svn: 106765
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp | 16 |
1 files changed, 4 insertions, 12 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp index fd8fe22f61d..bae24c093f0 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGBuilder.cpp @@ -1424,18 +1424,10 @@ void SelectionDAGBuilder::visitSwitchCase(CaseBlock &CB, MVT::Other, getControlRoot(), Cond, DAG.getBasicBlock(CB.TrueBB)); - // If the branch was constant folded, fix up the CFG. - if (BrCond.getOpcode() == ISD::BR) { - SwitchBB->removeSuccessor(CB.FalseBB); - } else { - // Otherwise, go ahead and insert the false branch. - if (BrCond == getControlRoot()) - SwitchBB->removeSuccessor(CB.TrueBB); - - if (CB.FalseBB != NextBlock) - BrCond = DAG.getNode(ISD::BR, dl, MVT::Other, BrCond, - DAG.getBasicBlock(CB.FalseBB)); - } + // Insert the false branch. + if (CB.FalseBB != NextBlock) + BrCond = DAG.getNode(ISD::BR, dl, MVT::Other, BrCond, + DAG.getBasicBlock(CB.FalseBB)); DAG.setRoot(BrCond); } |