blob: bc9769a53734473d36e65b5000df64848772f9fa [file] [log] [blame]
Evan Chengafff9412011-12-20 18:26:50 +00001; RUN: llc < %s -O0 -fast-isel-abort -relocation-model=dynamic-no-pic -mtriple=armv7-apple-ios | FileCheck %s --check-prefix=ARM
2; RUN: llc < %s -O0 -fast-isel-abort -relocation-model=dynamic-no-pic -mtriple=thumbv7-apple-ios | FileCheck %s --check-prefix=THUMB
Chad Rosier49d6fc02012-06-12 19:25:13 +00003; RUN: llc < %s -O0 -fast-isel-abort -relocation-model=dynamic-no-pic -mtriple=armv7-apple-ios -arm-long-calls | FileCheck %s --check-prefix=ARM-LONG
4; RUN: llc < %s -O0 -fast-isel-abort -relocation-model=dynamic-no-pic -mtriple=thumbv7-apple-ios -arm-long-calls | FileCheck %s --check-prefix=THUMB-LONG
Chad Rosier11add262011-11-11 23:31:03 +00005
Derek Schuffed788b62013-05-14 16:26:38 +00006; Note that some of these tests assume that relocations are either
7; movw/movt or constant pool loads. Different platforms will select
8; different approaches.
9
Chad Rosier11add262011-11-11 23:31:03 +000010@message1 = global [60 x i8] c"The LLVM Compiler Infrastructure\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00\00", align 1
11@temp = common global [60 x i8] zeroinitializer, align 1
12
13define void @t1() nounwind ssp {
14; ARM: t1
Derek Schuffed788b62013-05-14 16:26:38 +000015; ARM: {{(movw r0, :lower16:_?message1)|(ldr r0, .LCPI)}}
16; ARM: {{(movt r0, :upper16:_?message1)|(ldr r0, \[r0\])}}
Chad Rosier11add262011-11-11 23:31:03 +000017; ARM: add r0, r0, #5
18; ARM: movw r1, #64
19; ARM: movw r2, #10
20; ARM: uxtb r1, r1
Derek Schuffed788b62013-05-14 16:26:38 +000021; ARM: bl {{_?}}memset
Chad Rosier49d6fc02012-06-12 19:25:13 +000022; ARM-LONG: t1
23; ARM-LONG: movw r3, :lower16:L_memset$non_lazy_ptr
24; ARM-LONG: movt r3, :upper16:L_memset$non_lazy_ptr
25; ARM-LONG: ldr r3, [r3]
26; ARM-LONG: blx r3
Chad Rosier11add262011-11-11 23:31:03 +000027; THUMB: t1
Derek Schuffed788b62013-05-14 16:26:38 +000028; THUMB: {{(movw r0, :lower16:_?message1)|(ldr.n r0, .LCPI)}}
29; THUMB: {{(movt r0, :upper16:_?message1)|(ldr r0, \[r0\])}}
Chad Rosier11add262011-11-11 23:31:03 +000030; THUMB: adds r0, #5
31; THUMB: movs r1, #64
32; THUMB: movt r1, #0
33; THUMB: movs r2, #10
34; THUMB: movt r2, #0
35; THUMB: uxtb r1, r1
Derek Schuffed788b62013-05-14 16:26:38 +000036; THUMB: bl {{_?}}memset
Chad Rosier49d6fc02012-06-12 19:25:13 +000037; THUMB-LONG: t1
38; THUMB-LONG: movw r3, :lower16:L_memset$non_lazy_ptr
39; THUMB-LONG: movt r3, :upper16:L_memset$non_lazy_ptr
40; THUMB-LONG: ldr r3, [r3]
41; THUMB-LONG: blx r3
Chad Rosierc9758b12012-12-06 01:34:31 +000042 call void @llvm.memset.p0i8.i32(i8* getelementptr inbounds ([60 x i8]* @message1, i32 0, i32 5), i8 64, i32 10, i32 4, i1 false)
Chad Rosier11add262011-11-11 23:31:03 +000043 ret void
44}
45
46declare void @llvm.memset.p0i8.i32(i8* nocapture, i8, i32, i32, i1) nounwind
47
48define void @t2() nounwind ssp {
49; ARM: t2
Derek Schuffed788b62013-05-14 16:26:38 +000050; ARM: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr r0, .LCPI)}}
51; ARM: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosier11add262011-11-11 23:31:03 +000052; ARM: ldr r0, [r0]
53; ARM: add r1, r0, #4
54; ARM: add r0, r0, #16
Chad Rosier909cb4f2011-11-14 22:46:17 +000055; ARM: movw r2, #17
Derek Schuffed788b62013-05-14 16:26:38 +000056; ARM: str r0, [sp[[SLOT:[, #0-9]*]]] @ 4-byte Spill
Chad Rosier11add262011-11-11 23:31:03 +000057; ARM: mov r0, r1
Derek Schuffed788b62013-05-14 16:26:38 +000058; ARM: ldr r1, [sp[[SLOT]]] @ 4-byte Reload
59; ARM: bl {{_?}}memcpy
Chad Rosier49d6fc02012-06-12 19:25:13 +000060; ARM-LONG: t2
61; ARM-LONG: movw r3, :lower16:L_memcpy$non_lazy_ptr
62; ARM-LONG: movt r3, :upper16:L_memcpy$non_lazy_ptr
63; ARM-LONG: ldr r3, [r3]
64; ARM-LONG: blx r3
Chad Rosier11add262011-11-11 23:31:03 +000065; THUMB: t2
Derek Schuffed788b62013-05-14 16:26:38 +000066; THUMB: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr.n r0, .LCPI)}}
67; THUMB: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosier11add262011-11-11 23:31:03 +000068; THUMB: ldr r0, [r0]
69; THUMB: adds r1, r0, #4
70; THUMB: adds r0, #16
Chad Rosier909cb4f2011-11-14 22:46:17 +000071; THUMB: movs r2, #17
Chad Rosier11add262011-11-11 23:31:03 +000072; THUMB: movt r2, #0
Derek Schuffed788b62013-05-14 16:26:38 +000073; THUMB: str r0, [sp[[SLOT:[, #0-9]*]]] @ 4-byte Spill
Chad Rosier11add262011-11-11 23:31:03 +000074; THUMB: mov r0, r1
Derek Schuffed788b62013-05-14 16:26:38 +000075; THUMB: ldr r1, [sp[[SLOT]]] @ 4-byte Reload
76; THUMB: bl {{_?}}memcpy
Chad Rosier49d6fc02012-06-12 19:25:13 +000077; THUMB-LONG: t2
78; THUMB-LONG: movw r3, :lower16:L_memcpy$non_lazy_ptr
79; THUMB-LONG: movt r3, :upper16:L_memcpy$non_lazy_ptr
80; THUMB-LONG: ldr r3, [r3]
81; THUMB-LONG: blx r3
Chad Rosierc9758b12012-12-06 01:34:31 +000082 call void @llvm.memcpy.p0i8.p0i8.i32(i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 4), i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 16), i32 17, i32 4, i1 false)
Chad Rosier11add262011-11-11 23:31:03 +000083 ret void
84}
85
86declare void @llvm.memcpy.p0i8.p0i8.i32(i8* nocapture, i8* nocapture, i32, i32, i1) nounwind
87
88define void @t3() nounwind ssp {
89; ARM: t3
Derek Schuffed788b62013-05-14 16:26:38 +000090; ARM: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr r0, .LCPI)}}
91; ARM: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosier11add262011-11-11 23:31:03 +000092; ARM: ldr r0, [r0]
93; ARM: add r1, r0, #4
94; ARM: add r0, r0, #16
95; ARM: movw r2, #10
96; ARM: mov r0, r1
Derek Schuffed788b62013-05-14 16:26:38 +000097; ARM: bl {{_?}}memmove
Chad Rosier49d6fc02012-06-12 19:25:13 +000098; ARM-LONG: t3
99; ARM-LONG: movw r3, :lower16:L_memmove$non_lazy_ptr
100; ARM-LONG: movt r3, :upper16:L_memmove$non_lazy_ptr
101; ARM-LONG: ldr r3, [r3]
102; ARM-LONG: blx r3
Chad Rosier11add262011-11-11 23:31:03 +0000103; THUMB: t3
Derek Schuffed788b62013-05-14 16:26:38 +0000104; THUMB: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr.n r0, .LCPI)}}
105; THUMB: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosier11add262011-11-11 23:31:03 +0000106; THUMB: ldr r0, [r0]
107; THUMB: adds r1, r0, #4
108; THUMB: adds r0, #16
109; THUMB: movs r2, #10
110; THUMB: movt r2, #0
Derek Schuffed788b62013-05-14 16:26:38 +0000111; THUMB: str r0, [sp[[SLOT:[, #0-9]*]]] @ 4-byte Spill
Chad Rosier11add262011-11-11 23:31:03 +0000112; THUMB: mov r0, r1
Derek Schuffed788b62013-05-14 16:26:38 +0000113; THUMB: ldr r1, [sp[[SLOT]]] @ 4-byte Reload
114; THUMB: bl {{_?}}memmove
Chad Rosier49d6fc02012-06-12 19:25:13 +0000115; THUMB-LONG: t3
116; THUMB-LONG: movw r3, :lower16:L_memmove$non_lazy_ptr
117; THUMB-LONG: movt r3, :upper16:L_memmove$non_lazy_ptr
118; THUMB-LONG: ldr r3, [r3]
119; THUMB-LONG: blx r3
Chad Rosier11add262011-11-11 23:31:03 +0000120 call void @llvm.memmove.p0i8.p0i8.i32(i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 4), i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 16), i32 10, i32 1, i1 false)
121 ret void
122}
123
Chad Rosier909cb4f2011-11-14 22:46:17 +0000124define void @t4() nounwind ssp {
125; ARM: t4
Derek Schuffed788b62013-05-14 16:26:38 +0000126; ARM: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr r0, .LCPI)}}
127; ARM: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosier909cb4f2011-11-14 22:46:17 +0000128; ARM: ldr r0, [r0]
Jakob Stoklund Olesen4964ba02012-01-07 04:07:22 +0000129; ARM: ldr r1, [r0, #16]
130; ARM: str r1, [r0, #4]
131; ARM: ldr r1, [r0, #20]
132; ARM: str r1, [r0, #8]
133; ARM: ldrh r1, [r0, #24]
Chad Rosier909cb4f2011-11-14 22:46:17 +0000134; ARM: strh r1, [r0, #12]
135; ARM: bx lr
Chad Rosierc9758b12012-12-06 01:34:31 +0000136; THUMB: t4
Derek Schuffed788b62013-05-14 16:26:38 +0000137; THUMB: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr.n r0, .LCPI)}}
138; THUMB: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosier909cb4f2011-11-14 22:46:17 +0000139; THUMB: ldr r0, [r0]
Jakob Stoklund Olesen4964ba02012-01-07 04:07:22 +0000140; THUMB: ldr r1, [r0, #16]
141; THUMB: str r1, [r0, #4]
142; THUMB: ldr r1, [r0, #20]
143; THUMB: str r1, [r0, #8]
144; THUMB: ldrh r1, [r0, #24]
Chad Rosier909cb4f2011-11-14 22:46:17 +0000145; THUMB: strh r1, [r0, #12]
146; THUMB: bx lr
Chad Rosierc9758b12012-12-06 01:34:31 +0000147 call void @llvm.memcpy.p0i8.p0i8.i32(i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 4), i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 16), i32 10, i32 4, i1 false)
Chad Rosier909cb4f2011-11-14 22:46:17 +0000148 ret void
149}
150
Chad Rosier11add262011-11-11 23:31:03 +0000151declare void @llvm.memmove.p0i8.p0i8.i32(i8* nocapture, i8* nocapture, i32, i32, i1) nounwind
Chad Rosierc9758b12012-12-06 01:34:31 +0000152
153define void @t5() nounwind ssp {
154; ARM: t5
Derek Schuffed788b62013-05-14 16:26:38 +0000155; ARM: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr r0, .LCPI)}}
156; ARM: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosierc9758b12012-12-06 01:34:31 +0000157; ARM: ldr r0, [r0]
158; ARM: ldrh r1, [r0, #16]
159; ARM: strh r1, [r0, #4]
160; ARM: ldrh r1, [r0, #18]
161; ARM: strh r1, [r0, #6]
162; ARM: ldrh r1, [r0, #20]
163; ARM: strh r1, [r0, #8]
164; ARM: ldrh r1, [r0, #22]
165; ARM: strh r1, [r0, #10]
166; ARM: ldrh r1, [r0, #24]
167; ARM: strh r1, [r0, #12]
168; ARM: bx lr
169; THUMB: t5
Derek Schuffed788b62013-05-14 16:26:38 +0000170; THUMB: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr.n r0, .LCPI)}}
171; THUMB: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosierc9758b12012-12-06 01:34:31 +0000172; THUMB: ldr r0, [r0]
173; THUMB: ldrh r1, [r0, #16]
174; THUMB: strh r1, [r0, #4]
175; THUMB: ldrh r1, [r0, #18]
176; THUMB: strh r1, [r0, #6]
177; THUMB: ldrh r1, [r0, #20]
178; THUMB: strh r1, [r0, #8]
179; THUMB: ldrh r1, [r0, #22]
180; THUMB: strh r1, [r0, #10]
181; THUMB: ldrh r1, [r0, #24]
182; THUMB: strh r1, [r0, #12]
183; THUMB: bx lr
184 call void @llvm.memcpy.p0i8.p0i8.i32(i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 4), i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 16), i32 10, i32 2, i1 false)
185 ret void
186}
187
188define void @t6() nounwind ssp {
189; ARM: t6
Derek Schuffed788b62013-05-14 16:26:38 +0000190; ARM: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr r0, .LCPI)}}
191; ARM: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosierc9758b12012-12-06 01:34:31 +0000192; ARM: ldr r0, [r0]
193; ARM: ldrb r1, [r0, #16]
194; ARM: strb r1, [r0, #4]
195; ARM: ldrb r1, [r0, #17]
196; ARM: strb r1, [r0, #5]
197; ARM: ldrb r1, [r0, #18]
198; ARM: strb r1, [r0, #6]
199; ARM: ldrb r1, [r0, #19]
200; ARM: strb r1, [r0, #7]
201; ARM: ldrb r1, [r0, #20]
202; ARM: strb r1, [r0, #8]
203; ARM: ldrb r1, [r0, #21]
204; ARM: strb r1, [r0, #9]
205; ARM: ldrb r1, [r0, #22]
206; ARM: strb r1, [r0, #10]
207; ARM: ldrb r1, [r0, #23]
208; ARM: strb r1, [r0, #11]
209; ARM: ldrb r1, [r0, #24]
210; ARM: strb r1, [r0, #12]
211; ARM: ldrb r1, [r0, #25]
212; ARM: strb r1, [r0, #13]
213; ARM: bx lr
214; THUMB: t6
Derek Schuffed788b62013-05-14 16:26:38 +0000215; THUMB: {{(movw r0, :lower16:L_temp\$non_lazy_ptr)|(ldr.n r0, .LCPI)}}
216; THUMB: {{(movt r0, :upper16:L_temp\$non_lazy_ptr)?}}
Chad Rosierc9758b12012-12-06 01:34:31 +0000217; THUMB: ldr r0, [r0]
218; THUMB: ldrb r1, [r0, #16]
219; THUMB: strb r1, [r0, #4]
220; THUMB: ldrb r1, [r0, #17]
221; THUMB: strb r1, [r0, #5]
222; THUMB: ldrb r1, [r0, #18]
223; THUMB: strb r1, [r0, #6]
224; THUMB: ldrb r1, [r0, #19]
225; THUMB: strb r1, [r0, #7]
226; THUMB: ldrb r1, [r0, #20]
227; THUMB: strb r1, [r0, #8]
228; THUMB: ldrb r1, [r0, #21]
229; THUMB: strb r1, [r0, #9]
230; THUMB: ldrb r1, [r0, #22]
231; THUMB: strb r1, [r0, #10]
232; THUMB: ldrb r1, [r0, #23]
233; THUMB: strb r1, [r0, #11]
234; THUMB: ldrb r1, [r0, #24]
235; THUMB: strb r1, [r0, #12]
236; THUMB: ldrb r1, [r0, #25]
237; THUMB: strb r1, [r0, #13]
238; THUMB: bx lr
239 call void @llvm.memcpy.p0i8.p0i8.i32(i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 4), i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 16), i32 10, i32 1, i1 false)
240 ret void
241}
Chad Rosier848c25d2013-02-18 21:46:28 +0000242
Chad Rosier69c65b02013-02-18 21:59:15 +0000243; rdar://13202135
Chad Rosier848c25d2013-02-18 21:46:28 +0000244define void @t7() nounwind ssp {
245; Just make sure this doesn't assert when we have an odd length and an alignment of 2.
246 call void @llvm.memcpy.p0i8.p0i8.i32(i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 4), i8* getelementptr inbounds ([60 x i8]* @temp, i32 0, i32 16), i32 3, i32 2, i1 false)
247 ret void
248}
Chad Rosier33947b42013-03-07 20:42:17 +0000249
250define i32 @t8(i32 %x) nounwind {
251entry:
252; ARM: t8
253; ARM-NOT: FastISel missed call: %expval = call i32 @llvm.expect.i32(i32 %x, i32 1)
254; THUMB: t8
255; THUMB-NOT: FastISel missed call: %expval = call i32 @llvm.expect.i32(i32 %x, i32 1)
256 %expval = call i32 @llvm.expect.i32(i32 %x, i32 1)
257 ret i32 %expval
258}
259
260declare i32 @llvm.expect.i32(i32, i32) nounwind readnone