New testcase
[oota-llvm.git] / test / Transforms / DSAnalysis / arraytest.ll
1
2 %crazy = type [2 x { [2 x sbyte], short } ]
3
4 implementation
5
6 sbyte *%test1(%crazy* %P1) {    ; No merging, constant indexing
7         %P = getelementptr %crazy* %P1, long 0, long 0, ubyte 0, long 1
8         ret sbyte *%P
9 }
10
11 sbyte *%test2(%crazy* %P1) {    ; No merging, constant indexing
12         %P = getelementptr %crazy* %P1, long 0, long 1, ubyte 0, long 0
13         ret sbyte *%P
14 }
15
16 sbyte *%test3(%crazy* %P1) {    ; No merging, constant indexing, must handle outter index
17         %P = getelementptr %crazy* %P1, long -1, long 0, ubyte 0, long 0
18         ret sbyte *%P
19 }
20
21 sbyte *%mtest1(%crazy* %P1, long %idx) {    ; Merging deepest array
22         %P = getelementptr %crazy* %P1, long 0, long 0, ubyte 0, long %idx
23         ret sbyte *%P
24 }
25 sbyte *%mtest2(%crazy* %P1, long %idx) {    ; Merge top array
26         %P = getelementptr %crazy* %P1, long 0, long %idx, ubyte 0, long 1
27         ret sbyte *%P
28 }
29 sbyte *%mtest3(%crazy* %P1, long %idx) {    ; Merge array %crazy is in
30         %P = getelementptr %crazy* %P1, long %idx, long 0, ubyte 0, long 1
31         ret sbyte *%P
32 }
33
34 sbyte *%m2test1(%crazy* %P1, long %idx) {    ; Merge two arrays
35         %P = getelementptr %crazy* %P1, long 0, long %idx, ubyte 0, long %idx
36         ret sbyte *%P
37 }
38