summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--test/Transforms/DSAnalysis/arraytest.ll38
1 files changed, 38 insertions, 0 deletions
diff --git a/test/Transforms/DSAnalysis/arraytest.ll b/test/Transforms/DSAnalysis/arraytest.ll
new file mode 100644
index 0000000000..164eb744f3
--- /dev/null
+++ b/test/Transforms/DSAnalysis/arraytest.ll
@@ -0,0 +1,38 @@
+
+%crazy = type [2 x { [2 x sbyte], short } ]
+
+implementation
+
+sbyte *%test1(%crazy* %P1) { ; No merging, constant indexing
+ %P = getelementptr %crazy* %P1, long 0, long 0, ubyte 0, long 1
+ ret sbyte *%P
+}
+
+sbyte *%test2(%crazy* %P1) { ; No merging, constant indexing
+ %P = getelementptr %crazy* %P1, long 0, long 1, ubyte 0, long 0
+ ret sbyte *%P
+}
+
+sbyte *%test3(%crazy* %P1) { ; No merging, constant indexing, must handle outter index
+ %P = getelementptr %crazy* %P1, long -1, long 0, ubyte 0, long 0
+ ret sbyte *%P
+}
+
+sbyte *%mtest1(%crazy* %P1, long %idx) { ; Merging deepest array
+ %P = getelementptr %crazy* %P1, long 0, long 0, ubyte 0, long %idx
+ ret sbyte *%P
+}
+sbyte *%mtest2(%crazy* %P1, long %idx) { ; Merge top array
+ %P = getelementptr %crazy* %P1, long 0, long %idx, ubyte 0, long 1
+ ret sbyte *%P
+}
+sbyte *%mtest3(%crazy* %P1, long %idx) { ; Merge array %crazy is in
+ %P = getelementptr %crazy* %P1, long %idx, long 0, ubyte 0, long 1
+ ret sbyte *%P
+}
+
+sbyte *%m2test1(%crazy* %P1, long %idx) { ; Merge two arrays
+ %P = getelementptr %crazy* %P1, long 0, long %idx, ubyte 0, long %idx
+ ret sbyte *%P
+}
+