Fixed some bugs in register stack pass.
[llvm/zpu.git] / test / CodeGen / X86 / lsr-overflow.ll
blob0b0214c6d9f8a5baf5887c1f0124dc5428b545db
1 ; RUN: llc < %s -march=x86-64 | FileCheck %s
3 ; The comparison uses the pre-inc value, which could lead LSR to
4 ; try to compute -INT64_MIN.
6 ; CHECK: movabsq $-9223372036854775808, %rax
7 ; CHECK: cmpq  %rax, %rbx
8 ; CHECK: sete  %al
10 declare i64 @bar()
12 define i1 @foo() nounwind {
13 entry:
14   br label %for.cond.i
16 for.cond.i:
17   %indvar = phi i64 [ 0, %entry ], [ %indvar.next, %for.cond.i ]
18   %t = call i64 @bar()
19   %indvar.next = add i64 %indvar, 1
20   %s = icmp ne i64 %indvar.next, %t
21   br i1 %s, label %for.cond.i, label %__ABContainsLabel.exit
23 __ABContainsLabel.exit:
24   %cmp = icmp eq i64 %indvar, 9223372036854775807
25   ret i1 %cmp