summaryrefslogtreecommitdiffstats
path: root/clang
diff options
context:
space:
mode:
Diffstat (limited to 'clang')
-rw-r--r--clang/lib/CodeGen/CGExprScalar.cpp6
-rw-r--r--clang/test/CodeGen/conditional.c5
2 files changed, 9 insertions, 2 deletions
diff --git a/clang/lib/CodeGen/CGExprScalar.cpp b/clang/lib/CodeGen/CGExprScalar.cpp
index bdd7975fa0c..8442b8174e2 100644
--- a/clang/lib/CodeGen/CGExprScalar.cpp
+++ b/clang/lib/CodeGen/CGExprScalar.cpp
@@ -1050,7 +1050,8 @@ VisitConditionalOperator(const ConditionalOperator *E) {
// Handle the GNU extension for missing LHS.
Value *LHS;
if (E->getLHS())
- LHS = Visit(E->getLHS());
+ LHS = EmitScalarConversion(Visit(E->getLHS()), E->getLHS()->getType(),
+ E->getType());
else // Perform promotions, to handle cases like "short ?: int"
LHS = EmitScalarConversion(CondVal, E->getCond()->getType(), E->getType());
@@ -1059,7 +1060,8 @@ VisitConditionalOperator(const ConditionalOperator *E) {
CGF.EmitBlock(RHSBlock);
- Value *RHS = Visit(E->getRHS());
+ Value *RHS = EmitScalarConversion(Visit(E->getRHS()), E->getRHS()->getType(),
+ E->getType());
Builder.CreateBr(ContBlock);
RHSBlock = Builder.GetInsertBlock();
diff --git a/clang/test/CodeGen/conditional.c b/clang/test/CodeGen/conditional.c
index ae442071150..d3e5c0b9384 100644
--- a/clang/test/CodeGen/conditional.c
+++ b/clang/test/CodeGen/conditional.c
@@ -25,3 +25,8 @@ void test5() {
void* vp;
cip = 0 ? vp : cip;
}
+
+void test6();
+void test7(int);
+void* test8() {return 1 ? test6 : test7;}
+
OpenPOWER on IntegriCloud