Index: llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp =================================================================== --- llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp +++ llvm/lib/Transforms/InstCombine/InstCombineSelect.cpp @@ -2476,9 +2476,9 @@ // Check implication. BasicBlockEdge Incoming(Pred, BB); if (DT.dominates(TrueEdge, Incoming)) - Inputs[Pred] = IfTrue; + Inputs[Pred] = IfTrue->DoPHITranslation(BB, Pred); else if (DT.dominates(FalseEdge, Incoming)) - Inputs[Pred] = IfFalse; + Inputs[Pred] = IfFalse->DoPHITranslation(BB, Pred); else return nullptr; // Check availability. Index: llvm/test/Transforms/InstCombine/select.ll =================================================================== --- llvm/test/Transforms/InstCombine/select.ll +++ llvm/test/Transforms/InstCombine/select.ll @@ -2010,8 +2010,7 @@ ; CHECK: if.false: ; CHECK-NEXT: br label [[MERGE]] ; CHECK: merge: -; CHECK-NEXT: [[PHI:%.*]] = phi i32 [ 0, [[IF_TRUE]] ], [ [[Z:%.*]], [[IF_FALSE]] ] -; CHECK-NEXT: [[S:%.*]] = select i1 [[COND]], i32 [[X:%.*]], i32 [[PHI]] +; CHECK-NEXT: [[S:%.*]] = phi i32 [ [[Z:%.*]], [[IF_FALSE]] ], [ [[X:%.*]], [[IF_TRUE]] ] ; CHECK-NEXT: ret i32 [[S]] ; entry: