2 ; RUN: analyze %s -tddatastructure
3 %crazy = type [2 x { [2 x sbyte], short } ]
7 sbyte *%test1(%crazy* %P1) { ; No merging, constant indexing
8 %P = getelementptr %crazy* %P1, long 0, long 0, ubyte 0, long 1
12 sbyte *%test2(%crazy* %P1) { ; No merging, constant indexing
13 %P = getelementptr %crazy* %P1, long 0, long 1, ubyte 0, long 0
17 sbyte *%test3(%crazy* %P1) { ; No merging, constant indexing, must handle outter index
18 %P = getelementptr %crazy* %P1, long -1, long 0, ubyte 0, long 0
22 sbyte *%mtest1(%crazy* %P1, long %idx) { ; Merging deepest array
23 %P = getelementptr %crazy* %P1, long 0, long 0, ubyte 0, long %idx
26 sbyte *%mtest2(%crazy* %P1, long %idx) { ; Merge top array
27 %P = getelementptr %crazy* %P1, long 0, long %idx, ubyte 0, long 1
30 sbyte *%mtest3(%crazy* %P1, long %idx) { ; Merge array %crazy is in
31 %P = getelementptr %crazy* %P1, long %idx, long 0, ubyte 0, long 1
35 sbyte *%m2test1(%crazy* %P1, long %idx) { ; Merge two arrays
36 %P = getelementptr %crazy* %P1, long 0, long %idx, ubyte 0, long %idx