Index: llvm/trunk/lib/Transforms/InstCombine/InstructionCombining.cpp =================================================================== --- llvm/trunk/lib/Transforms/InstCombine/InstructionCombining.cpp +++ llvm/trunk/lib/Transforms/InstCombine/InstructionCombining.cpp @@ -939,9 +939,19 @@ // `TrueVInPred`. if (InC && !isa(InC) && isa(InC)) InV = InC->isNullValue() ? FalseVInPred : TrueVInPred; - else + else { + // Generate the select in the same block as PN's current incoming block. + // Note: ThisBB need not be the NonConstBB because vector constants + // which are constants by definition are handled here. + // FIXME: This can lead to an increase in IR generation because we might + // generate selects for vector constant phi operand, that could not be + // folded to TrueVInPred or FalseVInPred as done for ConstantInt. For + // non-vector phis, this transformation was always profitable because + // the select would be generated exactly once in the NonConstBB. + Builder->SetInsertPoint(ThisBB->getTerminator()); InV = Builder->CreateSelect(PN->getIncomingValue(i), TrueVInPred, FalseVInPred, "phitmp"); + } NewPN->addIncoming(InV, ThisBB); } } else if (CmpInst *CI = dyn_cast(&I)) { Index: llvm/trunk/test/Transforms/InstCombine/phi-select-constant.ll =================================================================== --- llvm/trunk/test/Transforms/InstCombine/phi-select-constant.ll +++ llvm/trunk/test/Transforms/InstCombine/phi-select-constant.ll @@ -55,3 +55,32 @@ %sel = select <4 x i1> %phinode, <4 x i64> zeroinitializer, <4 x i64> ret <4 x i64> %sel } + +; Test PR33364 +; Insert the generated select into the same block as the incoming phi value. +; phi has constant vectors along with a single non-constant vector as operands. +define <2 x i8> @vec3(i1 %cond1, i1 %cond2, <2 x i1> %x, <2 x i8> %y, <2 x i8> %z) { +; CHECK-LABEL: @vec3 +; CHECK-LABEL: entry: +; CHECK-NEXT: [[PHITMP1:%.*]] = shufflevector <2 x i8> %y, <2 x i8> %z, <2 x i32> +entry: + br i1 %cond1, label %if1, label %else + +; CHECK-LABEL: if1: +; CHECK-NEXT: [[PHITMP2:%.*]] = shufflevector <2 x i8> %y, <2 x i8> %z, <2 x i32> +if1: + br i1 %cond2, label %if2, label %else + +; CHECK-LABEL: if2: +; CHECK-NEXT: [[PHITMP3:%.*]] = select <2 x i1> %x, <2 x i8> %y, <2 x i8> %z +if2: + br label %else + +; CHECK-LABEL: else: +; CHECK-NEXT: [[PHITMP4:%.*]] = phi <2 x i8> [ [[PHITMP3]], %if2 ], [ [[PHITMP1]], %entry ], [ [[PHITMP2]], %if1 ] +; CHECK-NEXT: ret <2 x i8> [[PHITMP4]] +else: + %phi = phi <2 x i1> [ %x, %if2 ], [ , %entry ], [ , %if1 ] + %sel = select <2 x i1> %phi, <2 x i8> %y, <2 x i8> %z + ret <2 x i8> %sel +}