Owen Anderson | c004eec | 2010-09-21 18:41:19 +0000 | [diff] [blame] | 1 | ; RUN: llc < %s -march=x86 | FileCheck %s |
| 2 | ; <rdar://problem/8449754> |
| 3 | |
Chris Lattner | c19d1c3 | 2010-12-19 22:08:31 +0000 | [diff] [blame] | 4 | define i32 @test1(i32 %sum, i32 %x) nounwind readnone ssp { |
Owen Anderson | c004eec | 2010-09-21 18:41:19 +0000 | [diff] [blame] | 5 | entry: |
Chris Lattner | c19d1c3 | 2010-12-19 22:08:31 +0000 | [diff] [blame] | 6 | ; CHECK: test1: |
Owen Anderson | c004eec | 2010-09-21 18:41:19 +0000 | [diff] [blame] | 7 | ; CHECK: sbbl %ecx, %ecx |
| 8 | ; CHECK-NOT: addl |
| 9 | ; CHECK: subl %ecx, %eax |
| 10 | %add4 = add i32 %x, %sum |
| 11 | %cmp = icmp ult i32 %add4, %x |
| 12 | %inc = zext i1 %cmp to i32 |
| 13 | %z.0 = add i32 %add4, %inc |
| 14 | ret i32 %z.0 |
| 15 | } |
Chris Lattner | c19d1c3 | 2010-12-19 22:08:31 +0000 | [diff] [blame] | 16 | |
| 17 | ; Instcombine transforms test1 into test2: |
| 18 | ; CHECK: test2: |
| 19 | ; CHECK: movl |
| 20 | ; CHECK-NEXT: addl |
| 21 | ; CHECK-NEXT: sbbl |
| 22 | ; CHECK-NEXT: subl |
| 23 | ; CHECK-NEXT: ret |
| 24 | define i32 @test2(i32 %sum, i32 %x) nounwind readnone ssp { |
| 25 | entry: |
| 26 | %uadd = call { i32, i1 } @llvm.uadd.with.overflow.i32(i32 %x, i32 %sum) |
| 27 | %0 = extractvalue { i32, i1 } %uadd, 0 |
| 28 | %cmp = extractvalue { i32, i1 } %uadd, 1 |
| 29 | %inc = zext i1 %cmp to i32 |
| 30 | %z.0 = add i32 %0, %inc |
| 31 | ret i32 %z.0 |
| 32 | } |
| 33 | |
| 34 | declare { i32, i1 } @llvm.uadd.with.overflow.i32(i32, i32) nounwind readnone |