New testcase for the possible array merging scenarios
authorChris Lattner <sabre@nondot.org>
Thu, 31 Oct 2002 04:48:32 +0000 (04:48 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 31 Oct 2002 04:48:32 +0000 (04:48 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@4462 91177308-0d34-0410-b5e6-96231b3b80d8

test/Transforms/DSAnalysis/arraytest.ll [new file with mode: 0644]

diff --git a/test/Transforms/DSAnalysis/arraytest.ll b/test/Transforms/DSAnalysis/arraytest.ll
new file mode 100644 (file)
index 0000000..164eb74
--- /dev/null
@@ -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
+}
+