]> granicus.if.org Git - llvm/commitdiff
[PM] Make default pipeline test for the new PM strict
authorMichael Kuperstein <mkuper@google.com>
Thu, 19 Jan 2017 23:39:28 +0000 (23:39 +0000)
committerMichael Kuperstein <mkuper@google.com>
Thu, 19 Jan 2017 23:39:28 +0000 (23:39 +0000)
Use CHECK-NEXT to verify that a test breaks whenever unexpected passes,
analyses, or invalidations show up in default pipelines. The test case
is constructed so that we don't expect to invalidate anything, and needs
to be kept that way.

The test is slightly less strict than we'd like because of differences
in type pretty-printing.

(Right now it does show some invalidations - all of those are intentional
and temporary.)

Differential Revision: https://reviews.llvm.org/D28887

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

test/Other/new-pass-manager.ll
test/Other/new-pm-defaults.ll [new file with mode: 0644]

index 936da1daff2fa3e1c2482037f1a601fee9d82598..4134e81431c83565d53408654ba60326986d6c82 100644 (file)
 ; CHECK-O0: Starting llvm::Module pass manager run
 ; CHECK-O0-NEXT: Finished llvm::Module pass manager run
 
-; RUN: opt -disable-output -disable-verify -debug-pass-manager \
-; RUN:     -passes='default<O1>' %s 2>&1 \
-; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-O1
-; RUN: opt -disable-output -disable-verify -debug-pass-manager \
-; RUN:     -passes='default<O2>' %s 2>&1 \
-; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-O2
-; RUN: opt -disable-output -disable-verify -debug-pass-manager \
-; RUN:     -passes='default<Os>' %s 2>&1 \
-; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-Os
-; RUN: opt -disable-output -disable-verify -debug-pass-manager \
-; RUN:     -passes='default<Oz>' %s 2>&1 \
-; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-Oz
-; RUN: opt -disable-output -disable-verify -debug-pass-manager \
-; RUN:     -passes='lto-pre-link<O2>' %s 2>&1 \
-; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-O2
-; CHECK-O: Starting llvm::Module pass manager run
-; CHECK-O: Starting llvm::Module pass manager run
-; CHECK-O: Running pass: ForceFunctionAttrsPass
-; CHECK-O: Running pass: InferFunctionAttrsPass
-; CHECK-O: Starting llvm::Function pass manager run.
-; CHECK-O: Running pass: SimplifyCFGPass
-; CHECK-O: Running pass: SROA
-; CHECK-O: Running pass: EarlyCSEPass
-; CHECK-O: Running pass: LowerExpectIntrinsicPass
-; CHECK-O: Running pass: GVNHoistPass
-; CHECK-O: Finished llvm::Function pass manager run.
-; CHECK-O: Running pass: IPSCCPPass
-; CHECK-O: Running pass: GlobalOptPass
-; CHECK-O: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PromotePass>
-; CHECK-O: Running pass: DeadArgumentEliminationPass
-; CHECK-O: Starting llvm::Function pass manager run.
-; CHECK-O: Running pass: InstCombinePass
-; CHECK-O: Running pass: SimplifyCFGPass
-; CHECK-O: Finished llvm::Function pass manager run.
-; CHECK-O: Starting CGSCC pass manager run.
-; CHECK-O: Starting llvm::Function pass manager run.
-; CHECK-O: Running pass: SROA
-; CHECK-O: Running pass: EarlyCSEPass
-; CHECK-O: Running pass: SpeculativeExecutionPass
-; CHECK-O: Running pass: JumpThreadingPass
-; CHECK-O: Running pass: CorrelatedValuePropagationPass
-; CHECK-O: Running pass: SimplifyCFGPass
-; CHECK-O: Running pass: InstCombinePass
-; CHECK-O1: Running pass: LibCallsShrinkWrapPass
-; CHECK-O2: Running pass: LibCallsShrinkWrapPass
-; CHECK-Os-NOT: Running pass: LibCallsShrinkWrapPass
-; CHECK-Oz-NOT: Running pass: LibCallsShrinkWrapPass
-; CHECK-O: Running pass: TailCallElimPass
-; CHECK-O: Running pass: SimplifyCFGPass
-; CHECK-O: Running pass: ReassociatePass
-; CHECK-O: Starting Loop pass manager run.
-; CHECK-O: Finished Loop pass manager run.
-; CHECK-O: Running pass: SimplifyCFGPass
-; CHECK-O: Running pass: InstCombinePass
-; CHECK-O: Starting Loop pass manager run.
-; CHECK-O: Finished Loop pass manager run.
-; CHECK-O: Running pass: MemCpyOptPass
-; CHECK-O: Running pass: SCCPPass
-; CHECK-O: Running pass: BDCEPass
-; CHECK-O: Running pass: InstCombinePass
-; CHECK-O: Running pass: JumpThreadingPass
-; CHECK-O: Running pass: CorrelatedValuePropagationPass
-; CHECK-O: Running pass: DSEPass
-; CHECK-O: Running pass: ADCEPass
-; CHECK-O: Running pass: SimplifyCFGPass
-; CHECK-O: Running pass: InstCombinePass
-; CHECK-O: Finished llvm::Function pass manager run.
-; CHECK-O: Finished CGSCC pass manager run.
-; CHECK-O: Running pass: EliminateAvailableExternallyPass
-; CHECK-O: Running pass: ReversePostOrderFunctionAttrsPass
-; CHECK-O: Starting llvm::Function pass manager run.
-; CHECK-O: Running pass: Float2IntPass
-; CHECK-O: Running pass: LoopDistributePass
-; CHECK-O: Running pass: LoopVectorizePass
-; CHECK-O: Running pass: InstCombinePass
-; CHECK-O: Running pass: SLPVectorizerPass
-; CHECK-O: Running pass: SimplifyCFGPass
-; CHECK-O: Running pass: InstCombinePass
-; CHECK-O: Running pass: AlignmentFromAssumptionsPass
-; CHECK-O: Finished llvm::Function pass manager run.
-; CHECK-O: Running pass: GlobalDCEPass
-; CHECK-O: Running pass: ConstantMergePass
-
 ; RUN: opt -disable-output -disable-verify -debug-pass-manager \
 ; RUN:     -passes='lto<O2>' %s 2>&1 \
 ; RUN:     | FileCheck %s --check-prefix=CHECK-LTO-O2
diff --git a/test/Other/new-pm-defaults.ll b/test/Other/new-pm-defaults.ll
new file mode 100644 (file)
index 0000000..8df334a
--- /dev/null
@@ -0,0 +1,176 @@
+; The IR below was crafted so as:
+; 1) To have a loop, so we create a loop pass manager
+; 2) To be "immutable" in the sense that no pass in the standard
+;    pipeline will modify it.
+; Since no transformations take place, we don't expect any analyses
+; to be invalidated.
+; Any invalidation that shows up here is a bug, unless we started modifying
+; the IR, in which case we need to make it immutable harder.
+
+; RUN: opt -disable-verify -debug-pass-manager \
+; RUN:     -passes='default<O1>' -S %s 2>&1 \
+; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-O1
+; RUN: opt -disable-verify -debug-pass-manager \
+; RUN:     -passes='default<O2>' -S  %s 2>&1 \
+; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-O2
+; RUN: opt -disable-verify -debug-pass-manager \
+; RUN:     -passes='default<O3>' -S  %s 2>&1 \
+; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-O3
+; RUN: opt -disable-verify -debug-pass-manager \
+; RUN:     -passes='default<Os>' -S %s 2>&1 \
+; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-Os
+; RUN: opt -disable-verify -debug-pass-manager \
+; RUN:     -passes='default<Oz>' -S %s 2>&1 \
+; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-Oz
+; RUN: opt -disable-verify -debug-pass-manager \
+; RUN:     -passes='lto-pre-link<O2>' -S %s 2>&1 \
+; RUN:     | FileCheck %s --check-prefix=CHECK-O --check-prefix=CHECK-O2
+
+;CHECK-O: Starting llvm::Module pass manager run.
+;CHECK-O-NEXT: Running pass: PassManager<llvm::Module>
+;CHECK-O-NEXT: Starting llvm::Module pass manager run.
+;CHECK-O-NEXT: Running pass: ForceFunctionAttrsPass
+;CHECK-O-NEXT: Running pass: InferFunctionAttrsPass
+;CHECK-O-NEXT: Running analysis: TargetLibraryAnalysis
+;CHECK-O-NEXT: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PassManager{{.*}}>
+;CHECK-O-NEXT: Running analysis: InnerAnalysisManagerProxy
+;CHECK-O-NEXT: Starting llvm::Function pass manager run.
+;CHECK-O-NEXT: Running pass: SimplifyCFGPass
+;CHECK-O-NEXT: Running analysis: TargetIRAnalysis
+;CHECK-O-NEXT: Running analysis: AssumptionAnalysis
+;CHECK-O-NEXT: Running pass: SROA
+;CHECK-O-NEXT: Running analysis: DominatorTreeAnalysis
+;CHECK-O-NEXT: Running pass: EarlyCSEPass
+;CHECK-O-NEXT: Running analysis: TargetLibraryAnalysis
+;CHECK-O-NEXT: Running pass: LowerExpectIntrinsicPass
+;CHECK-O-NEXT: Running pass: GVNHoistPass
+;CHECK-O-NEXT: Running analysis: AAManager
+;CHECK-O-NEXT: Running analysis: MemoryDependenceAnalysis
+;CHECK-O-NEXT: Running analysis: MemorySSAAnalysis
+;CHECK-O-NEXT: Finished llvm::Function pass manager run.
+;CHECK-O-NEXT: Running pass: IPSCCPPass
+;CHECK-O-NEXT: Running pass: GlobalOptPass
+;CHECK-O-NEXT: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PromotePass>
+;CHECK-O-NEXT: Running pass: DeadArgumentEliminationPass
+;CHECK-O-NEXT: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PassManager{{.*}}>
+;CHECK-O-NEXT: Starting llvm::Function pass manager run.
+;CHECK-O-NEXT: Running pass: InstCombinePass
+;CHECK-O-NEXT: Running pass: SimplifyCFGPass
+;CHECK-O-NEXT: Finished llvm::Function pass manager run.
+;CHECK-O-NEXT: Running pass: ModuleToPostOrderCGSCCPassAdaptor<{{.*}}LazyCallGraph{{.*}}>
+;CHECK-O-NEXT: Running analysis: InnerAnalysisManagerProxy
+;CHECK-O-NEXT: Running analysis: LazyCallGraphAnalysis
+;CHECK-O-NEXT: Starting CGSCC pass manager run.
+;CHECK-O-NEXT: Running pass: InlinerPass
+;CHECK-O-NEXT: Running analysis: FunctionAnalysisManagerCGSCCProxy
+;CHECK-O-NEXT: Running analysis: OuterAnalysisManagerProxy<{{.*}}LazyCallGraph{{.*}}>
+;CHECK-O-NEXT: Running analysis: OptimizationRemarkEmitterAnalysis
+;CHECK-O-NEXT: Running pass: PostOrderFunctionAttrsPass
+;CHECK-O-NEXT: Running pass: CGSCCToFunctionPassAdaptor<{{.*}}PassManager{{.*}}>
+;CHECK-O-NEXT: Starting llvm::Function pass manager run.
+;CHECK-O-NEXT: Running pass: SROA
+;CHECK-O-NEXT: Running pass: EarlyCSEPass
+;CHECK-O-NEXT: Running pass: SpeculativeExecutionPass
+;CHECK-O-NEXT: Running pass: JumpThreadingPass
+;CHECK-O-NEXT: Running analysis: LazyValueAnalysis
+;CHECK-O-NEXT: Invalidating analysis: LazyValueAnalysis
+;CHECK-O-NEXT: Running pass: CorrelatedValuePropagationPass
+;CHECK-O-NEXT: Running analysis: LazyValueAnalysis
+;CHECK-O-NEXT: Invalidating analysis: LazyValueAnalysis
+;CHECK-O-NEXT: Running pass: SimplifyCFGPass
+;CHECK-O-NEXT: Running pass: InstCombinePass
+;CHECK-O1-NEXT: Running pass: LibCallsShrinkWrapPass
+;CHECK-O2-NEXT: Running pass: LibCallsShrinkWrapPass
+;CHECK-O3-NEXT: Running pass: LibCallsShrinkWrapPass
+;CHECK-O-NEXT: Running pass: TailCallElimPass
+;CHECK-O-NEXT: Running pass: SimplifyCFGPass
+;CHECK-O-NEXT: Running pass: ReassociatePass
+;CHECK-O-NEXT: Running pass: FunctionToLoopPassAdaptor<{{.*}}LoopStandardAnalysisResults{{.*}}>
+;CHECK-O-NEXT: Running analysis: LoopAnalysis
+;CHECK-O-NEXT: Running analysis: InnerAnalysisManagerProxy
+;CHECK-O-NEXT: Running analysis: ScalarEvolutionAnalysis
+;CHECK-O-NEXT: Starting Loop pass manager run.
+;CHECK-O-NEXT: Finished Loop pass manager run.
+;CHECK-O-NEXT: Running pass: SimplifyCFGPass
+;CHECK-O-NEXT: Running pass: InstCombinePass
+;CHECK-O-NEXT: Running pass: FunctionToLoopPassAdaptor<{{.*}}LoopStandardAnalysisResults{{.*}}>
+;CHECK-O-NEXT: Starting Loop pass manager run.
+;CHECK-O-NEXT: Finished Loop pass manager run.
+;CHECK-Os-NEXT: Running pass: MergedLoadStoreMotionPass
+;CHECK-Os-NEXT: Running pass: GVN
+;CHECK-Oz-NEXT: Running pass: MergedLoadStoreMotionPass
+;CHECK-Oz-NEXT: Running pass: GVN
+;CHECK-O2-NEXT: Running pass: MergedLoadStoreMotionPass
+;CHECK-O2-NEXT: Running pass: GVN
+;CHECK-O3-NEXT: Running pass: MergedLoadStoreMotionPass
+;CHECK-O3-NEXT: Running pass: GVN
+;CHECK-O-NEXT: Running pass: MemCpyOptPass
+;CHECK-O-NEXT: Running pass: SCCPPass
+;CHECK-O-NEXT: Running pass: BDCEPass
+;CHECK-O-NEXT: Running analysis: DemandedBitsAnalysis
+;CHECK-O-NEXT: Running pass: InstCombinePass
+;CHECK-O-NEXT: Running pass: JumpThreadingPass
+;CHECK-O-NEXT: Running analysis: LazyValueAnalysis
+;CHECK-O-NEXT: Invalidating analysis: LazyValueAnalysis
+;CHECK-O-NEXT: Running pass: CorrelatedValuePropagationPass
+;CHECK-O-NEXT: Running analysis: LazyValueAnalysis
+;CHECK-O-NEXT: Invalidating analysis: LazyValueAnalysis
+;CHECK-O-NEXT: Running pass: DSEPass
+;CHECK-O-NEXT: Running pass: ADCEPass
+;CHECK-O-NEXT: Running analysis: PostDominatorTreeAnalysis
+;CHECK-O-NEXT: Running pass: SimplifyCFGPass
+;CHECK-O-NEXT: Running pass: InstCombinePass
+;CHECK-O-NEXT: Finished llvm::Function pass manager run.
+;CHECK-O-NEXT: Finished CGSCC pass manager run.
+;CHECK-O-NEXT: Running pass: EliminateAvailableExternallyPass
+;CHECK-O-NEXT: Running pass: ReversePostOrderFunctionAttrsPass
+;CHECK-O-NEXT: Running analysis: CallGraphAnalysis
+;CHECK-O-NEXT: Invalidating analysis: CallGraphAnalysis
+;CHECK-O-NEXT: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PassManager{{.*}}>
+;CHECK-O-NEXT: Starting llvm::Function pass manager run.
+;CHECK-O-NEXT: Running pass: Float2IntPass
+;CHECK-O-NEXT: Running pass: LoopDistributePass
+;CHECK-O-NEXT: Running pass: LoopVectorizePass
+;CHECK-O-NEXT: Running analysis: BlockFrequencyAnalysis
+;CHECK-O-NEXT: Running analysis: BranchProbabilityAnalysis
+;CHECK-O-NEXT: Running pass: InstCombinePass
+;CHECK-O-NEXT: Running pass: SLPVectorizerPass
+;CHECK-O-NEXT: Running pass: SimplifyCFGPass
+;CHECK-O-NEXT: Running pass: InstCombinePass
+;CHECK-O-NEXT: Running pass: AlignmentFromAssumptionsPass
+;CHECK-O-NEXT: Invalidating analysis: ScalarEvolutionAnalysis
+;CHECK-O-NEXT: Finished llvm::Function pass manager run.
+;CHECK-O-NEXT: Running pass: GlobalDCEPass
+;CHECK-O-NEXT: Running pass: ConstantMergePass
+;CHECK-O-NEXT: Finished llvm::Module pass manager run.
+;CHECK-O-NEXT: Running pass: PrintModulePass
+
+;CHECK-O-LABEL: define void @foo(i32 %n) local_unnamed_addr {
+;CHECK-O-NEXT: entry:
+;CHECK-O-NEXT:   br label %loop
+;CHECK-O:      loop:
+;CHECK-O-NEXT:   %iv = phi i32 [ 0, %entry ], [ %iv.next, %loop ]
+;CHECK-O-NEXT:   %iv.next = add i32 %iv, 1
+;CHECK-O-NEXT:   tail call void @bar()
+;CHECK-O-NEXT:   %cmp = icmp eq i32 %iv, %n
+;CHECK-O-NEXT:   br i1 %cmp, label %exit, label %loop
+;CHECK-O:      exit:
+;CHECK-O-NEXT:   ret void
+;CHECK-O-NEXT: }
+
+;CHECK-O-NEXT: Finished llvm::Module pass manager run.
+
+declare void @bar() local_unnamed_addr
+
+define void @foo(i32 %n) local_unnamed_addr {
+entry:
+  br label %loop
+loop:
+  %iv = phi i32 [ 0, %entry ], [ %iv.next, %loop ]
+  %iv.next = add i32 %iv, 1
+  tail call void @bar()
+  %cmp = icmp eq i32 %iv, %n
+  br i1 %cmp, label %exit, label %loop
+exit:
+  ret void
+}