diff options
-rw-r--r-- | llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp | 2 | ||||
-rw-r--r-- | llvm/test/Transforms/SLPVectorizer/X86/crash_knl.ll | 17 |
2 files changed, 19 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp index 09ae5517c8c..4d023c925d2 100644 --- a/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp +++ b/llvm/lib/Transforms/Vectorize/SLPVectorizer.cpp @@ -3765,6 +3765,8 @@ void SLPVectorizerPass::collectSeedInstructions(BasicBlock *BB) { continue; if (!isValidElementType(Idx->getType())) continue; + if (GEP->getType()->isVectorTy()) + continue; GEPs[GetUnderlyingObject(GEP->getPointerOperand(), *DL)].push_back(GEP); } } diff --git a/llvm/test/Transforms/SLPVectorizer/X86/crash_knl.ll b/llvm/test/Transforms/SLPVectorizer/X86/crash_knl.ll new file mode 100644 index 00000000000..5f37258ff05 --- /dev/null +++ b/llvm/test/Transforms/SLPVectorizer/X86/crash_knl.ll @@ -0,0 +1,17 @@ +;RUN: opt < %s -slp-vectorizer -S + +target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" +target triple = "x86_64-unknown-linux-gnu" + +; Function Attrs: noreturn readonly uwtable +define void @_Z3fn1v(i32 %x, <16 x i32*>%y) local_unnamed_addr #0 { +entry: + %conv42.le = sext i32 %x to i64 + %conv36109.le = zext i32 2 to i64 + %VectorGep = getelementptr i32, <16 x i32*> %y, i64 %conv36109.le + %VectorGep208 = getelementptr i32, <16 x i32*> %y, i64 %conv42.le + unreachable +} + +attributes #0 = { noreturn readonly uwtable "disable-tail-calls"="false" "less-precise-fpmad"="false" "no-frame-pointer-elim"="false" "no-infs-fp-math"="false" "no-jump-tables"="false" "no-nans-fp-math"="false" "stack-protector-buffer-size"="8" "target-cpu"="knl" "target-features"="+adx,+aes,+avx,+avx2,+avx512cd,+avx512er,+avx512f,+avx512pf,+bmi,+bmi2,+cx16,+f16c,+fma,+fsgsbase,+fxsr,+lzcnt,+mmx,+movbe,+pclmul,+popcnt,+prefetchwt1,+rdrnd,+rdseed,+rtm,+sse,+sse2,+sse3,+sse4.1,+sse4.2,+ssse3,+x87,+xsave,+xsaveopt" "unsafe-fp-math"="false" "use-soft-float"="false" } + |