llvm-project/llvm/test/CodeGen/X86/loop-strength-reduce-crash.ll

26 lines
691 B
LLVM

; RUN: opt -loop-reduce < %s -o /dev/null
; LSR doesn't actually do anything on this input; just check that it doesn't
; crash while building the compatible type for the IV (by virtue of using
; INT64_MAX as a constant in the loop).
target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
target triple = "x86_64-apple-macosx10.12.0"
define void @foo() {
entry:
br label %for
for:
%0 = phi i64 [ %add, %for ], [ undef, %entry ]
%next = phi i32 [ %inc, %for ], [ undef, %entry ]
store i32 %next, i32* undef, align 4
%add = add i64 %0, 9223372036854775807
%inc = add nsw i32 %next, 1
br i1 undef, label %exit, label %for
exit:
store i64 %add, i64* undef
ret void
}