Add a testcase that checks to make sure LICM uses basicaa correctly.
authorChris Lattner <sabre@nondot.org>
Thu, 22 Aug 2002 20:22:55 +0000 (20:22 +0000)
committerChris Lattner <sabre@nondot.org>
Thu, 22 Aug 2002 20:22:55 +0000 (20:22 +0000)
Add another gcse testcase.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3471 91177308-0d34-0410-b5e6-96231b3b80d8

test/Analysis/BasicAA/gcsetest.ll
test/Analysis/BasicAA/licmtest.ll [new file with mode: 0644]
test/Transforms/BasicAA/gcsetest.ll
test/Transforms/BasicAA/licmtest.ll [new file with mode: 0644]

index f6f7db933d39213e074024465b50294fdd4c372d..a49f3130bb03e77d024cc1ace0570e1d50facccf 100644 (file)
@@ -21,3 +21,19 @@ int %test() {
        ret int %X
 }
 
+int %test2() {
+        %A1 = load int* %A
+        br label %Loop
+Loop:
+        %AP = phi int [0, %0], [%X, %Loop]
+        store int %AP, int* %B  ; Store cannot alias %A
+
+        %A2 = load int* %A
+        %X = sub int %A1, %A2
+        %c = seteq int %X, 0
+        br bool %c, label %out, label %Loop
+
+out:
+        ret int %X
+}
+
diff --git a/test/Analysis/BasicAA/licmtest.ll b/test/Analysis/BasicAA/licmtest.ll
new file mode 100644 (file)
index 0000000..92f58e8
--- /dev/null
@@ -0,0 +1,31 @@
+; Test that LICM uses basicaa to do alias analysis, which is capable of 
+; disambiguating some obvious cases.  The ToRemove load should be eliminated
+; in this testcase.  This testcase was carefully contrived so that GCSE would
+; not be able to eliminate the load itself, without licm's help.  This is 
+; because, for GCSE, the load is killed by the dummy basic block.
+
+; RUN: if as < %s | opt -basicaa -licm -gcse -simplifycfg -instcombine | dis | grep ToRemove
+; RUN: then exit 1
+; RUN: else exit 0
+; RUN: fi
+
+%A = global int 7
+%B = global int 8
+implementation
+
+int %test(bool %c) {
+       %Atmp = load int* %A
+       br label %Loop
+Loop:
+       %ToRemove = load int* %A
+       store int %ToRemove, int* %B  ; Store cannot alias %A
+
+       br bool %c, label %Out, label %Loop
+Out:
+       ret int 7
+
+Dummy:
+       store int 7, int* %A
+       br label %Loop
+}
+
index f6f7db933d39213e074024465b50294fdd4c372d..a49f3130bb03e77d024cc1ace0570e1d50facccf 100644 (file)
@@ -21,3 +21,19 @@ int %test() {
        ret int %X
 }
 
+int %test2() {
+        %A1 = load int* %A
+        br label %Loop
+Loop:
+        %AP = phi int [0, %0], [%X, %Loop]
+        store int %AP, int* %B  ; Store cannot alias %A
+
+        %A2 = load int* %A
+        %X = sub int %A1, %A2
+        %c = seteq int %X, 0
+        br bool %c, label %out, label %Loop
+
+out:
+        ret int %X
+}
+
diff --git a/test/Transforms/BasicAA/licmtest.ll b/test/Transforms/BasicAA/licmtest.ll
new file mode 100644 (file)
index 0000000..92f58e8
--- /dev/null
@@ -0,0 +1,31 @@
+; Test that LICM uses basicaa to do alias analysis, which is capable of 
+; disambiguating some obvious cases.  The ToRemove load should be eliminated
+; in this testcase.  This testcase was carefully contrived so that GCSE would
+; not be able to eliminate the load itself, without licm's help.  This is 
+; because, for GCSE, the load is killed by the dummy basic block.
+
+; RUN: if as < %s | opt -basicaa -licm -gcse -simplifycfg -instcombine | dis | grep ToRemove
+; RUN: then exit 1
+; RUN: else exit 0
+; RUN: fi
+
+%A = global int 7
+%B = global int 8
+implementation
+
+int %test(bool %c) {
+       %Atmp = load int* %A
+       br label %Loop
+Loop:
+       %ToRemove = load int* %A
+       store int %ToRemove, int* %B  ; Store cannot alias %A
+
+       br bool %c, label %Out, label %Loop
+Out:
+       ret int 7
+
+Dummy:
+       store int 7, int* %A
+       br label %Loop
+}
+