diff options
-rw-r--r-- | test/Transforms/DSAnalysis/arraytest.ll | 38 |
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 +} + |