diff options
| author | Chris Lattner <sabre@nondot.org> | 2008-11-11 18:56:45 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2008-11-11 18:56:45 +0000 | 
| commit | d53e23328ea02ee11c1715e2c12e35b6c5217fec (patch) | |
| tree | e27e496c7aa10eb8f0cd477b22340122468d47ff | |
| parent | c3b41e31fbd07029f60fd1237a7e6ca73da93f1d (diff) | |
| download | bcm5719-llvm-d53e23328ea02ee11c1715e2c12e35b6c5217fec.tar.gz bcm5719-llvm-d53e23328ea02ee11c1715e2c12e35b6c5217fec.zip | |
Try to not emit the dead side of ?: if the condition is a constant.
llvm-svn: 59061
| -rw-r--r-- | clang/lib/CodeGen/CGExprScalar.cpp | 25 | 
1 files changed, 21 insertions, 4 deletions
| diff --git a/clang/lib/CodeGen/CGExprScalar.cpp b/clang/lib/CodeGen/CGExprScalar.cpp index 82f0cc7e777..bf22902b68b 100644 --- a/clang/lib/CodeGen/CGExprScalar.cpp +++ b/clang/lib/CodeGen/CGExprScalar.cpp @@ -1110,14 +1110,31 @@ Value *ScalarExprEmitter::VisitBinComma(const BinaryOperator *E) {  Value *ScalarExprEmitter::  VisitConditionalOperator(const ConditionalOperator *E) { -  llvm::BasicBlock *LHSBlock = CGF.createBasicBlock("cond.?"); -  llvm::BasicBlock *RHSBlock = CGF.createBasicBlock("cond.:"); -  llvm::BasicBlock *ContBlock = CGF.createBasicBlock("cond.cont"); -      // Evaluate the conditional, then convert it to bool.  We do this explicitly    // because we need the unconverted value if this is a GNU ?: expression with    // missing middle value.    Value *CondVal = CGF.EmitScalarExpr(E->getCond()); + +  // If the condition folded to a constant, try to elide the dead side.  We +  // can't do this if the dead side contains a label. +  if (llvm::ConstantInt *CondCI = dyn_cast<llvm::ConstantInt>(CondVal)) { +    Expr *Live = E->getLHS(), *Dead = E->getRHS(); +    if (CondCI->getZExtValue() == 0) +      std::swap(Live, Dead); +    if (!Dead || !CGF.ContainsLabel(Dead)) { +      // Emit the live side. +      if (Live) +        return Visit(Live); +      // Perform promotions, to handle cases like "short ?: int" +      return EmitScalarConversion(CondVal, E->getCond()->getType(), +                                  E->getType()); +    }    +  } +   +  llvm::BasicBlock *LHSBlock = CGF.createBasicBlock("cond.?"); +  llvm::BasicBlock *RHSBlock = CGF.createBasicBlock("cond.:"); +  llvm::BasicBlock *ContBlock = CGF.createBasicBlock("cond.cont"); +      Value *CondBoolVal =CGF.EmitScalarConversion(CondVal, E->getCond()->getType(),                                                 CGF.getContext().BoolTy);    Builder.CreateCondBr(CondBoolVal, LHSBlock, RHSBlock); | 

