[llvm] r292530 - [PM] Make default pipeline test for the new PM strict

Michael Kuperstein via llvm-commits llvm-commits at lists.llvm.org
Thu Jan 19 14:55:47 PST 2017


Author: mkuper
Date: Thu Jan 19 16:55:46 2017
New Revision: 292530

URL: http://llvm.org/viewvc/llvm-project?rev=292530&view=rev
Log:
[PM] Make default pipeline test for the new PM strict

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.

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

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

Added:
    llvm/trunk/test/Other/new-pm-defaults.ll
Modified:
    llvm/trunk/test/Other/new-pass-manager.ll

Modified: llvm/trunk/test/Other/new-pass-manager.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Other/new-pass-manager.ll?rev=292530&r1=292529&r2=292530&view=diff
==============================================================================
--- llvm/trunk/test/Other/new-pass-manager.ll (original)
+++ llvm/trunk/test/Other/new-pass-manager.ll Thu Jan 19 16:55:46 2017
@@ -384,89 +384,6 @@
 ; 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
 ; CHECK-LTO-O2: Starting llvm::Module pass manager run

Added: llvm/trunk/test/Other/new-pm-defaults.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Other/new-pm-defaults.ll?rev=292530&view=auto
==============================================================================
--- llvm/trunk/test/Other/new-pm-defaults.ll (added)
+++ llvm/trunk/test/Other/new-pm-defaults.ll Thu Jan 19 16:55:46 2017
@@ -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<{{.*}}LazyCallGraph{{.*}}>
+;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<{{.*}}LoopStandardAnalysisResults{{.*}}>
+;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
+}




More information about the llvm-commits mailing list