1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-10-19 02:52:53 +02:00
llvm-mirror/test/Transforms/InstCombine/preserved-analyses.ll
Chandler Carruth fa2e854de5 [PM] Fix instcombine's analysis preservation in the new pass manager to
cover domtree and alias analysis. These are the pretty clear analyses
that we would always want to survive this pass.

To make these survive, we also need to preserve the assumption cache.

Added a test that verifies the important bits of this preservation.

llvm-svn: 292037
2017-01-14 23:25:22 +00:00

34 lines
1.3 KiB
LLVM

; This is really testing that instcombine preserves analyses correctly, so we
; don't care much about the code other than it is something instcombine can
; transform.
;
; RUN: opt < %s -disable-output -debug-pass-manager 2>&1 -aa-pipeline=basic-aa,globals-aa \
; RUN: -passes='require<globals-aa>,function(require<aa>,instcombine),function(require<aa>)' \
; RUN: | FileCheck %s --check-prefix=AA
; AA: Running analysis: GlobalsAA
; AA: Running analysis: AAManager
; AA: Running analysis: BasicAA
; AA: Running pass: InstCombinePass on test
; AA-NOT: Invalidating analysis: GlobalsAA
; AA-NOT: Invalidating analysis: AAmanager
; AA-NOT: Invalidating analysis: BasicAA
; AA: Running pass: RequireAnalysisPass<{{.*}}AAManager
; AA-NOT: Running analysis: GlobalsAA
; AA-NOT: Running analysis: AAmanager
; AA-NOT: Running analysis: BasicAA
;
; RUN: opt < %s -disable-output -debug-pass-manager 2>&1 \
; RUN: -passes='require<domtree>,instcombine,require<domtree>' \
; RUN: | FileCheck %s --check-prefix=DT
; DT: Running analysis: DominatorTreeAnalysis
; DT: Running pass: InstCombinePass on test
; DT-NOT: Invalidating analysis: DominatorTreeAnalysis
; DT: Running pass: RequireAnalysisPass<{{.*}}DominatorTreeAnalysis
; DT-NOT: Running analysis: DominatorTreeAnalysis
define i32 @test(i32 %A) {
%B = add i32 %A, 5
%C = add i32 %B, -5
ret i32 %C
}