1; RUN: llc -mtriple thumbv7--windows-itanium -print-machineinstrs=expand-isel-pseudos -verify-machineinstrs -o /dev/null %s 2>&1 | FileCheck %s -check-prefix CHECK-DIV
2
3; int f(int n, int d) {
4;   if (n / d)
5;     return 1;
6;   return 0;
7; }
8
9define arm_aapcs_vfpcc i32 @f(i32 %n, i32 %d) {
10entry:
11  %retval = alloca i32, align 4
12  %n.addr = alloca i32, align 4
13  %d.addr = alloca i32, align 4
14  store i32 %n, i32* %n.addr, align 4
15  store i32 %d, i32* %d.addr, align 4
16  %0 = load i32, i32* %n.addr, align 4
17  %1 = load i32, i32* %d.addr, align 4
18  %div = sdiv i32 %0, %1
19  %tobool = icmp ne i32 %div, 0
20  br i1 %tobool, label %if.then, label %if.end
21
22if.then:
23  store i32 1, i32* %retval, align 4
24  br label %return
25
26if.end:
27  store i32 0, i32* %retval, align 4
28  br label %return
29
30return:
31  %2 = load i32, i32* %retval, align 4
32  ret i32 %2
33}
34
35; CHECK-DIV-DAG: BB#0
36; CHECK-DIV-DAG: Successors according to CFG: BB#5({{.*}}) BB#4
37; CHECK-DIV-DAG: BB#1
38; CHECK-DIV-DAG: Successors according to CFG: BB#3
39; CHECK-DIV-DAG: BB#2
40; CHECK-DIV-DAG: Successors according to CFG: BB#3
41; CHECK-DIV-DAG: BB#3
42; CHECK-DIV-DAG: BB#4
43; CHECK-DIV-DAG: Successors according to CFG: BB#1({{.*}}) BB#2
44; CHECK-DIV-DAG: BB#5
45
46; RUN: llc -mtriple thumbv7--windows-itanium -print-machineinstrs=expand-isel-pseudos -verify-machineinstrs -o /dev/null %s 2>&1 | FileCheck %s -check-prefix CHECK-MOD
47
48; int r;
49; int g(int l, int m) {
50;   if (m <= 0)
51;     return 0;
52;   return (r = l % m);
53; }
54
55@r = common global i32 0, align 4
56
57define arm_aapcs_vfpcc i32 @g(i32 %l, i32 %m) {
58entry:
59  %cmp = icmp eq i32 %m, 0
60  br i1 %cmp, label %return, label %if.end
61
62if.end:
63  %rem = urem i32 %l, %m
64  store i32 %rem, i32* @r, align 4
65  br label %return
66
67return:
68  %retval.0 = phi i32 [ %rem, %if.end ], [ 0, %entry ]
69  ret i32 %retval.0
70}
71
72; CHECK-MOD-DAG: BB#0
73; CHECK-MOD-DAG: Successors according to CFG: BB#2({{.*}}) BB#1
74; CHECK-MOD-DAG: BB#1
75; CHECK-MOD-DAG: Successors according to CFG: BB#4({{.*}}) BB#3
76; CHECK-MOD-DAG: BB#2
77; CHECK-MOD-DAG: BB#3
78; CHECK-MOD-DAG: Successors according to CFG: BB#2
79; CHECK-MOD-DAG: BB#4
80
81; RUN: llc -mtriple thumbv7--windows-itanium -print-machineinstrs=expand-isel-pseudos -verify-machineinstrs -filetype asm -o /dev/null %s 2>&1 | FileCheck %s -check-prefix CHECK-CFG
82; RUN: llc -mtriple thumbv7--windows-itanium -print-machineinstrs=expand-isel-pseudos -verify-machineinstrs -filetype asm -o - %s | FileCheck %s -check-prefix CHECK-CFG-ASM
83
84; unsigned c;
85; extern unsigned long g(void);
86; int f(unsigned u, signed char b) {
87;   if (b)
88;     c = g() % u;
89;   return c;
90; }
91
92@c = common global i32 0, align 4
93
94declare arm_aapcs_vfpcc i32 @i()
95
96define arm_aapcs_vfpcc i32 @h(i32 %u, i8 signext %b) #0 {
97entry:
98  %tobool = icmp eq i8 %b, 0
99  br i1 %tobool, label %entry.if.end_crit_edge, label %if.then
100
101entry.if.end_crit_edge:
102  %.pre = load i32, i32* @c, align 4
103  br label %if.end
104
105if.then:
106  %call = tail call arm_aapcs_vfpcc i32 @i()
107  %rem = urem i32 %call, %u
108  store i32 %rem, i32* @c, align 4
109  br label %if.end
110
111if.end:
112  %0 = phi i32 [ %.pre, %entry.if.end_crit_edge ], [ %rem, %if.then ]
113  ret i32 %0
114}
115
116attributes #0 = { optsize }
117
118; CHECK-CFG-DAG: BB#0
119; CHECK-CFG-DAG: t2Bcc <BB#2>
120; CHECK-CFG-DAG: t2B <BB#1>
121
122; CHECK-CFG-DAG: BB#1
123; CHECK-CFG-DAG: t2B <BB#3>
124
125; CHECK-CFG-DAG: BB#2
126; CHECK-CFG-DAG: tCBZ %vreg{{[0-9]}}, <BB#5>
127; CHECK-CFG-DAG: t2B <BB#4>
128
129; CHECK-CFG-DAG: BB#4
130
131; CHECK-CFG-DAG: BB#3
132; CHECK-CFG-DAG: tBX_RET
133
134; CHECK-CFG-DAG: BB#5
135; CHECK-CFG-DAG: t2UDF 249
136
137; CHECK-CFG-ASM-LABEL: h:
138; CHECK-CFG-ASM: cbz r{{[0-9]}}, .LBB2_2
139; CHECK-CFG-ASM: b .LBB2_4
140; CHECK-CFG-ASM-LABEL: .LBB2_2:
141; CHECK-CFG-ASM-NEXT: udf.w #249
142; CHECK-CFG-ASM-LABEL: .LBB2_4:
143; CHECK-CFG-ASM: bl __rt_udiv
144; CHECK-CFG-ASM: pop.w {{{.*}}, r11, pc}
145
146; RUN: llc -O0 -mtriple thumbv7--windows-itanium -verify-machineinstrs -filetype asm -o - %s | FileCheck %s -check-prefix CHECK-WIN__DBZCHK
147
148; long k(void);
149; int l(void);
150; int j(int i) {
151;   if (l() == -1)
152;     return 0;
153;   return k() % i;
154; }
155
156declare arm_aapcs_vfpcc i32 @k()
157declare arm_aapcs_vfpcc i32 @l()
158
159define arm_aapcs_vfpcc i32 @j(i32 %i) {
160entry:
161  %retval = alloca i32, align 4
162  %i.addr = alloca i32, align 4
163  store i32 %i, i32* %i.addr, align 4
164  %call = call arm_aapcs_vfpcc i32 @l()
165  %cmp = icmp eq i32 %call, -1
166  br i1 %cmp, label %if.then, label %if.end
167
168if.then:
169  store i32 0, i32* %retval, align 4
170  br label %return
171
172if.end:
173  %call1 = call arm_aapcs_vfpcc i32 @k()
174  %0 = load i32, i32* %i.addr, align 4
175  %rem = srem i32 %call1, %0
176  store i32 %rem, i32* %retval, align 4
177  br label %return
178
179return:
180  %1 = load i32, i32* %retval, align 4
181  ret i32 %1
182}
183
184; CHECK-WIN__DBZCHK-LABEL: j:
185; CHECK-WIN__DBZCHK: cbz r{{[0-7]}}, .LBB
186; CHECK-WIN__DBZCHK-NOT: cbz r8, .LBB
187; CHECK-WIN__DBZCHK-NOT: cbz r9, .LBB
188; CHECK-WIN__DBZCHK-NOT: cbz r10, .LBB
189; CHECK-WIN__DBZCHK-NOT: cbz r11, .LBB
190; CHECK-WIN__DBZCHK-NOT: cbz ip, .LBB
191; CHECK-WIN__DBZCHK-NOT: cbz lr, .LBB
192
193