From: Michael Liao Date: Mon, 20 Aug 2012 17:59:18 +0000 (+0000) Subject: fix a case where all operands of BUILD_VECTOR are undefined X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=24438b83595dd243e4562912750ef15438787a42;p=oota-llvm.git fix a case where all operands of BUILD_VECTOR are undefined git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@162214 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Target/X86/X86ISelLowering.cpp b/lib/Target/X86/X86ISelLowering.cpp index e4af736844b..1bbd4a76406 100644 --- a/lib/Target/X86/X86ISelLowering.cpp +++ b/lib/Target/X86/X86ISelLowering.cpp @@ -5180,6 +5180,10 @@ X86TargetLowering::LowerVectorFpExtend(SDValue &Op, SelectionDAG &DAG) const { Mask.push_back(cast(L2In.getOperand(1))->getZExtValue()); } + // Quit if all operands of BUILD_VECTOR are undefined. + if (!VecIn.getNode()) + return SDValue(); + // Fill the remaining mask as undef. for (unsigned i = NumElts; i < VecInVT.getVectorNumElements(); ++i) Mask.push_back(-1); diff --git a/test/CodeGen/X86/pr11334.ll b/test/CodeGen/X86/pr11334.ll index 5b7b5eab87e..e7e29e0d609 100644 --- a/test/CodeGen/X86/pr11334.ll +++ b/test/CodeGen/X86/pr11334.ll @@ -54,3 +54,11 @@ entry: %f1 = fpext <8 x float> %v1 to <8 x double> ret <8 x double> %f1 } + +define void @test_vector_creation() nounwind { + %1 = insertelement <4 x double> undef, double 0.000000e+00, i32 2 + %2 = load double addrspace(1)* null + %3 = insertelement <4 x double> %1, double %2, i32 3 + store <4 x double> %3, <4 x double>* undef + ret void +}