diff options
Diffstat (limited to 'llvm/test/Transforms/LoopVectorize/pr38800.ll')
-rwxr-xr-x | llvm/test/Transforms/LoopVectorize/pr38800.ll | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/llvm/test/Transforms/LoopVectorize/pr38800.ll b/llvm/test/Transforms/LoopVectorize/pr38800.ll new file mode 100755 index 00000000000..d3e937b5b76 --- /dev/null +++ b/llvm/test/Transforms/LoopVectorize/pr38800.ll @@ -0,0 +1,34 @@ +; RUN: opt -loop-vectorize -force-vector-width=2 -pass-remarks-missed='loop-vectorize' -S < %s 2>&1 | FileCheck %s + +; CHECK: remark: <unknown>:0:0: loop not vectorized: integer loop induction variable could not be identified + +; Test-case ('-O2 -ffast-math') from PR38800. +; (Set '-force-vector-width=2' to enable vector code generation.) +; +; No integral induction variable in the source-code caused a compiler-crash +; when attempting to vectorize. With the fix, a remark indicating why it +; wasn't vectorized is produced +; +;void foo(float *ptr, float val) { +; float f; +; for (f = 0.1f; f < 1.0f; f += 0.01f) +; *ptr += val; +;} + +define void @foo(float* nocapture %ptr, float %val) local_unnamed_addr { +entry: + %ptr.promoted = load float, float* %ptr, align 4 + br label %for.body + +for.body: ; preds = %entry, %for.body + %add5 = phi float [ %ptr.promoted, %entry ], [ %add, %for.body ] + %f.04 = phi float [ 0x3FB99999A0000000, %entry ], [ %add1, %for.body ] + %add = fadd fast float %add5, %val + %add1 = fadd fast float %f.04, 0x3F847AE140000000 + %cmp = fcmp fast olt float %add1, 1.000000e+00 + br i1 %cmp, label %for.body, label %for.end + +for.end: ; preds = %for.body + store float %add, float* %ptr, align 4 + ret void +} |