blob: 9a2dc82d1894380cfdb5b1a409ce8e88ab804fe7 [file] [log] [blame]
Bob Wilsonb9350312009-10-27 06:16:45 +00001; RUN: llc < %s -mtriple=arm-apple-darwin | FileCheck %s
Evan Cheng02b985c2007-01-19 09:20:23 +00002
Tanya Lattner6263f942008-02-17 20:02:20 +00003@X = external global [0 x i32] ; <[0 x i32]*> [#uses=5]
Evan Cheng02b985c2007-01-19 09:20:23 +00004
Tanya Lattner6263f942008-02-17 20:02:20 +00005define i32 @t1() {
Bob Wilsonb9350312009-10-27 06:16:45 +00006; CHECK: t1:
7; CHECK: ldmia
Tanya Lattner6263f942008-02-17 20:02:20 +00008 %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 0) ; <i32> [#uses=1]
9 %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 1) ; <i32> [#uses=1]
10 %tmp4 = tail call i32 @f1( i32 %tmp, i32 %tmp3 ) ; <i32> [#uses=1]
11 ret i32 %tmp4
Evan Cheng02b985c2007-01-19 09:20:23 +000012}
13
Tanya Lattner6263f942008-02-17 20:02:20 +000014define i32 @t2() {
Bob Wilsonb9350312009-10-27 06:16:45 +000015; CHECK: t2:
16; CHECK: ldmia
Tanya Lattner6263f942008-02-17 20:02:20 +000017 %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 2) ; <i32> [#uses=1]
18 %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 3) ; <i32> [#uses=1]
19 %tmp5 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 4) ; <i32> [#uses=1]
20 %tmp6 = tail call i32 @f2( i32 %tmp, i32 %tmp3, i32 %tmp5 ) ; <i32> [#uses=1]
21 ret i32 %tmp6
Evan Cheng02b985c2007-01-19 09:20:23 +000022}
23
Tanya Lattner6263f942008-02-17 20:02:20 +000024define i32 @t3() {
Bob Wilsonb9350312009-10-27 06:16:45 +000025; CHECK: t3:
26; CHECK: ldmib
Bob Wilsonea7f22c2010-03-16 16:19:07 +000027; CHECK: ldmia sp!
Tanya Lattner6263f942008-02-17 20:02:20 +000028 %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 1) ; <i32> [#uses=1]
29 %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 2) ; <i32> [#uses=1]
30 %tmp5 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 3) ; <i32> [#uses=1]
31 %tmp6 = tail call i32 @f2( i32 %tmp, i32 %tmp3, i32 %tmp5 ) ; <i32> [#uses=1]
32 ret i32 %tmp6
Evan Cheng02b985c2007-01-19 09:20:23 +000033}
34
Tanya Lattner6263f942008-02-17 20:02:20 +000035declare i32 @f1(i32, i32)
36
37declare i32 @f2(i32, i32, i32)