blob: 6a054577fc8bfa806ee92f25ad0bb5029125f6a4 [file] [log] [blame]
Tanya Lattner6263f942008-02-17 20:02:20 +00001; RUN: llvm-as < %s | llc -march=arm | \
Dan Gohman28beeea2007-08-15 13:36:28 +00002; RUN: grep ldmia | count 2
Tanya Lattner6263f942008-02-17 20:02:20 +00003; RUN: llvm-as < %s | llc -march=arm | \
Dan Gohman28beeea2007-08-15 13:36:28 +00004; RUN: grep ldmib | count 1
Tanya Lattner6263f942008-02-17 20:02:20 +00005; RUN: llvm-as < %s | llc -mtriple=arm-apple-darwin | \
Dan Gohman28beeea2007-08-15 13:36:28 +00006; RUN: grep {ldmfd sp\!} | count 3
Evan Cheng02b985c2007-01-19 09:20:23 +00007
Tanya Lattner6263f942008-02-17 20:02:20 +00008@X = external global [0 x i32] ; <[0 x i32]*> [#uses=5]
Evan Cheng02b985c2007-01-19 09:20:23 +00009
Tanya Lattner6263f942008-02-17 20:02:20 +000010define i32 @t1() {
11 %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 0) ; <i32> [#uses=1]
12 %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 1) ; <i32> [#uses=1]
13 %tmp4 = tail call i32 @f1( i32 %tmp, i32 %tmp3 ) ; <i32> [#uses=1]
14 ret i32 %tmp4
Evan Cheng02b985c2007-01-19 09:20:23 +000015}
16
Tanya Lattner6263f942008-02-17 20:02:20 +000017define i32 @t2() {
18 %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 2) ; <i32> [#uses=1]
19 %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 3) ; <i32> [#uses=1]
20 %tmp5 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 4) ; <i32> [#uses=1]
21 %tmp6 = tail call i32 @f2( i32 %tmp, i32 %tmp3, i32 %tmp5 ) ; <i32> [#uses=1]
22 ret i32 %tmp6
Evan Cheng02b985c2007-01-19 09:20:23 +000023}
24
Tanya Lattner6263f942008-02-17 20:02:20 +000025define i32 @t3() {
26 %tmp = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 1) ; <i32> [#uses=1]
27 %tmp3 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 2) ; <i32> [#uses=1]
28 %tmp5 = load i32* getelementptr ([0 x i32]* @X, i32 0, i32 3) ; <i32> [#uses=1]
29 %tmp6 = tail call i32 @f2( i32 %tmp, i32 %tmp3, i32 %tmp5 ) ; <i32> [#uses=1]
30 ret i32 %tmp6
Evan Cheng02b985c2007-01-19 09:20:23 +000031}
32
Tanya Lattner6263f942008-02-17 20:02:20 +000033declare i32 @f1(i32, i32)
34
35declare i32 @f2(i32, i32, i32)