blob: 99ba475ad7b1ad1f07c06b7e9c33da75ea3d24e4 [file] [log] [blame]
Manman Renbe4258a2012-06-02 05:37:44 +00001; RUN: llc < %s -mtriple=armv7-apple-ios6.0 | FileCheck %s
2
3; rdar://9877866
4%struct.SmallStruct = type { i32, [8 x i32], [37 x i8] }
5%struct.LargeStruct = type { i32, [1001 x i8], [300 x i32] }
6
7define i32 @f() nounwind ssp {
8entry:
9; CHECK: f:
10; CHECK: ldr
11; CHECK: str
12; CHECK-NOT:bne
13 %st = alloca %struct.SmallStruct, align 4
14 %call = call i32 @e1(%struct.SmallStruct* byval %st)
15 ret i32 0
16}
17
18; Generate a loop for large struct byval
19define i32 @g() nounwind ssp {
20entry:
21; CHECK: g:
22; CHECK: ldr
23; CHECK: sub
24; CHECK: str
25; CHECK: bne
26 %st = alloca %struct.LargeStruct, align 4
27 %call = call i32 @e2(%struct.LargeStruct* byval %st)
28 ret i32 0
29}
30
Manman Reneda9fdf2012-06-18 22:23:48 +000031; Generate a loop using NEON instructions
32define i32 @h() nounwind ssp {
33entry:
34; CHECK: h:
35; CHECK: vld1
36; CHECK: sub
37; CHECK: vst1
38; CHECK: bne
39 %st = alloca %struct.LargeStruct, align 16
40 %call = call i32 @e3(%struct.LargeStruct* byval align 16 %st)
41 ret i32 0
42}
43
Manman Renbe4258a2012-06-02 05:37:44 +000044declare i32 @e1(%struct.SmallStruct* nocapture byval %in) nounwind
45declare i32 @e2(%struct.LargeStruct* nocapture byval %in) nounwind
Manman Reneda9fdf2012-06-18 22:23:48 +000046declare i32 @e3(%struct.LargeStruct* nocapture byval align 16 %in) nounwind