mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
Add a testcase that checks to make sure LICM uses basicaa correctly.
Add another gcse testcase. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3471 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c20e24524f
commit
8673e44639
@ -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
|
||||
}
|
||||
|
||||
|
31
test/Analysis/BasicAA/licmtest.ll
Normal file
31
test/Analysis/BasicAA/licmtest.ll
Normal file
@ -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
|
||||
}
|
||||
|
@ -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
|
||||
}
|
||||
|
||||
|
31
test/Transforms/BasicAA/licmtest.ll
Normal file
31
test/Transforms/BasicAA/licmtest.ll
Normal file
@ -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
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user