aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--test/Analysis/BasicAA/gcsetest.ll16
-rw-r--r--test/Analysis/BasicAA/licmtest.ll31
-rw-r--r--test/Transforms/BasicAA/gcsetest.ll16
-rw-r--r--test/Transforms/BasicAA/licmtest.ll31
4 files changed, 94 insertions, 0 deletions
diff --git a/test/Analysis/BasicAA/gcsetest.ll b/test/Analysis/BasicAA/gcsetest.ll
index f6f7db9..a49f313 100644
--- a/test/Analysis/BasicAA/gcsetest.ll
+++ b/test/Analysis/BasicAA/gcsetest.ll
@@ -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
index 0000000..92f58e8
--- /dev/null
+++ b/test/Analysis/BasicAA/licmtest.ll
@@ -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
+}
+
diff --git a/test/Transforms/BasicAA/gcsetest.ll b/test/Transforms/BasicAA/gcsetest.ll
index f6f7db9..a49f313 100644
--- a/test/Transforms/BasicAA/gcsetest.ll
+++ b/test/Transforms/BasicAA/gcsetest.ll
@@ -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
index 0000000..92f58e8
--- /dev/null
+++ b/test/Transforms/BasicAA/licmtest.ll
@@ -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
+}
+