[InstCombine] Signed saturation tests. NFC
[llvm-complete.git] / test / Transforms / CodeGenPrepare / ARM / overflow-intrinsics.ll
blob3fbc21331410d0963661587c09ab63a2dd4f58a8
1 ; RUN: opt -codegenprepare -S < %s | FileCheck %s
3 target datalayout = "e-m:e-p:32:32-i64:64-v128:64:128-a:0:32-n32-S64"
4 target triple = "thumbv8m.main-arm-none-eabi"
6 ; CHECK-LABEL: uadd_overflow_too_far_cmp_dom
7 ; CHECK-NOT: with.overflow.i32
8 define i32 @uadd_overflow_too_far_cmp_dom(i32 %arg0) {
9 entry:
10   %cmp = icmp ne i32 %arg0, 0
11   br i1 %cmp, label %if.else, label %if.then
13 if.then:
14   call void @foo()
15   br label %exit
17 if.else:
18   call void @bar()
19   br label %if.end
21 if.end:
22   %dec = add nsw i32 %arg0, -1
23   br label %exit
25 exit:
26   %res = phi i32 [ %arg0, %if.then ], [ %dec, %if.end ]
27   ret i32 %res
30 ; CHECK-LABEL: uadd_overflow_too_far_math_dom
31 ; CHECK-NOT: with.overflow.i32
32 define i32 @uadd_overflow_too_far_math_dom(i32 %arg0, i32 %arg1) {
33 entry:
34   %dec = add nsw i32 %arg0, -1
35   %cmp = icmp ugt i32 %arg0, 1
36   br i1 %cmp, label %if.else, label %if.then
38 if.then:
39   call void @foo()
40   br label %if.end
42 if.else:
43   call void @bar()
44   br label %if.end
46 if.end:
47   %cmp.i.i = icmp ne i32 %arg0, 0
48   %tobool = zext i1 %cmp.i.i to i32
49   br label %exit
51 exit:
52   ret i32 %tobool
55 declare void @foo()
56 declare void @bar()