summaryrefslogtreecommitdiff
path: root/test/CodeGen/X86/lsr-overflow.ll
blob: eb6fa905b5a10756f564899c02bd03d1c2763e14 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
; RUN: llc < %s -march=x86-64 | FileCheck %s

; The comparison uses the pre-inc value, which could lead LSR to
; try to compute -INT64_MIN.

; CHECK: movabsq $-9223372036854775808, %rax ## imm = 0x8000000000000000
; CHECK: cmpq  %rax, %rbx
; CHECK: sete  %al

declare i64 @bar()

define i1 @foo() nounwind {
entry:
  br label %for.cond.i

for.cond.i:
  %indvar = phi i64 [ 0, %entry ], [ %indvar.next, %for.cond.i ]
  %t = call i64 @bar()
  %indvar.next = add i64 %indvar, 1
  %s = icmp ne i64 %indvar.next, %t
  br i1 %s, label %for.cond.i, label %__ABContainsLabel.exit

__ABContainsLabel.exit:
  %cmp = icmp eq i64 %indvar, 9223372036854775807
  ret i1 %cmp
}