blob: 6fcbdee30d340a19f336b39ae3e6dd14f19b8bf2 [file] [log] [blame]
Manman Ren247c5ab2012-05-11 01:30:47 +00001; RUN: llc < %s -mtriple=arm-apple-darwin | FileCheck %s
2
3define i32 @f(i32 %a, i32 %b) nounwind ssp {
4entry:
5; CHECK: f:
6; CHECK: subs
7; CHECK-NOT: cmp
8 %cmp = icmp sgt i32 %a, %b
9 %sub = sub nsw i32 %a, %b
10 %sub. = select i1 %cmp, i32 %sub, i32 0
11 ret i32 %sub.
12}
13
14define i32 @g(i32 %a, i32 %b) nounwind ssp {
15entry:
16; CHECK: g:
17; CHECK: subs
18; CHECK-NOT: cmp
19 %cmp = icmp slt i32 %a, %b
20 %sub = sub nsw i32 %b, %a
21 %sub. = select i1 %cmp, i32 %sub, i32 0
22 ret i32 %sub.
23}
24
25define i32 @h(i32 %a, i32 %b) nounwind ssp {
26entry:
27; CHECK: h:
28; CHECK: subs
29; CHECK-NOT: cmp
30 %cmp = icmp sgt i32 %a, 3
31 %sub = sub nsw i32 %a, 3
32 %sub. = select i1 %cmp, i32 %sub, i32 %b
33 ret i32 %sub.
34}
Manman Ren540cda32012-06-25 21:49:38 +000035
36; rdar://11725965
37define i32 @i(i32 %a, i32 %b) nounwind readnone ssp {
38entry:
39; CHECK: i:
40; CHECK: subs
41; CHECK-NOT: cmp
42 %cmp = icmp ult i32 %a, %b
43 %sub = sub i32 %b, %a
44 %sub. = select i1 %cmp, i32 %sub, i32 0
45 ret i32 %sub.
46}
Manman Ren45ed1942012-07-11 22:51:44 +000047; If CPSR is live-out, we can't remove cmp if there exists
48; a swapped sub.
49define i32 @j(i32 %a, i32 %b) nounwind {
50entry:
51; CHECK: j:
52; CHECK: sub
53; CHECK: cmp
54 %cmp = icmp eq i32 %b, %a
55 %sub = sub nsw i32 %a, %b
56 br i1 %cmp, label %if.then, label %if.else
57
58if.then:
59 %cmp2 = icmp sgt i32 %b, %a
60 %sel = select i1 %cmp2, i32 %sub, i32 %a
61 ret i32 %sel
62
63if.else:
64 ret i32 %sub
65}