1; Validate ThinLTO postlink pipeline when we have Sample PGO
2;
3; RUN: opt -disable-verify -debug-pass-manager \
4; RUN:     -pgo-kind=pgo-sample-use-pipeline -profile-file='%S/Inputs/new-pm-thinlto-samplepgo-defaults.prof' \
5; RUN:     -passes='thinlto<O1>' -S %s 2>&1 \
6; RUN:     | FileCheck %s --check-prefixes=CHECK-O,CHECK-O1,%llvmcheckext --dump-input=fail
7; RUN: opt -disable-verify -debug-pass-manager \
8; RUN:     -pgo-kind=pgo-sample-use-pipeline -profile-file='%S/Inputs/new-pm-thinlto-samplepgo-defaults.prof' \
9; RUN:     -passes='thinlto<O2>' -S  %s 2>&1 \
10; RUN:     | FileCheck %s --check-prefixes=CHECK-O,CHECK-O2,CHECK-O23SZ,%llvmcheckext --dump-input=fail
11; RUN: opt -disable-verify -debug-pass-manager -passes-ep-pipeline-start='no-op-module' \
12; RUN:     -pgo-kind=pgo-sample-use-pipeline -profile-file='%S/Inputs/new-pm-thinlto-samplepgo-defaults.prof' \
13; RUN:     -passes='thinlto<O3>' -S  %s 2>&1 \
14; RUN:     | FileCheck %s --check-prefixes=CHECK-O,CHECK-O3,CHECK-O23SZ,%llvmcheckext --dump-input=fail
15; RUN: opt -disable-verify -debug-pass-manager \
16; RUN:     -pgo-kind=pgo-sample-use-pipeline -profile-file='%S/Inputs/new-pm-thinlto-samplepgo-defaults.prof' \
17; RUN:     -passes='thinlto<Os>' -S %s 2>&1 \
18; RUN:     | FileCheck %s --check-prefixes=CHECK-O,CHECK-Os,CHECK-O23SZ,%llvmcheckext --dump-input=fail
19; RUN: opt -disable-verify -debug-pass-manager \
20; RUN:     -pgo-kind=pgo-sample-use-pipeline -profile-file='%S/Inputs/new-pm-thinlto-samplepgo-defaults.prof' \
21; RUN:     -passes='thinlto<Oz>' -S %s 2>&1 \
22; RUN:     | FileCheck %s --check-prefixes=CHECK-O,CHECK-Oz,CHECK-O23SZ,%llvmcheckext --dump-input=fail
23; RUN: opt -disable-verify -debug-pass-manager -new-pm-debug-info-for-profiling \
24; RUN:     -pgo-kind=pgo-sample-use-pipeline -profile-file='%S/Inputs/new-pm-thinlto-samplepgo-defaults.prof' \
25; RUN:     -passes='thinlto<O2>' -S  %s 2>&1 \
26; RUN:     | FileCheck %s --check-prefixes=CHECK-O,CHECK-O2,CHECK-O23SZ,%llvmcheckext --dump-input=fail
27;
28; CHECK-O: Running analysis: PassInstrumentationAnalysis
29; CHECK-O-NEXT: Starting {{.*}}Module pass manager run.
30; CHECK-O-NEXT: Running pass: PassManager<{{.*}}Module{{.*}}>
31; CHECK-O-NEXT: Starting {{.*}}Module pass manager run.
32; CHECK-O-NEXT: Running pass: ForceFunctionAttrsPass
33; CHECK-EP-PIPELINE-START-NEXT: Running pass: NoOpModulePass
34; CHECK-O-NEXT: Running pass: PassManager<{{.*}}Module{{.*}}>
35; CHECK-O-NEXT: Starting {{.*}}Module pass manager run.
36; CHECK-O-NEXT: Running pass: InferFunctionAttrsPass
37; CHECK-O-NEXT: Running analysis: InnerAnalysisManagerProxy
38; CHECK-O-NEXT: Running analysis: TargetLibraryAnalysis
39; CHECK-O-NEXT: Running analysis: PassInstrumentationAnalysis
40; CHECK-O-NEXT: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PassManager{{.*}}>
41; CHECK-O-NEXT: Running analysis: PassInstrumentationAnalysis
42; CHECK-O-NEXT: Starting {{.*}}Function pass manager run.
43; CHECK-O-NEXT: Running pass: SimplifyCFGPass
44; CHECK-O-NEXT: Running analysis: TargetIRAnalysis
45; CHECK-O-NEXT: Running analysis: AssumptionAnalysis
46; CHECK-O-NEXT: Running pass: SROA
47; CHECK-O-NEXT: Running analysis: DominatorTreeAnalysis
48; CHECK-O-NEXT: Running pass: EarlyCSEPass
49; CHECK-O-NEXT: Running analysis: TargetLibraryAnalysis
50; CHECK-O-NEXT: Running pass: LowerExpectIntrinsicPass
51; CHECK-O3-NEXT: Running pass: CallSiteSplittingPass
52; CHECK-O-NEXT: Running pass: InstCombinePass on foo
53; CHECK-O-NEXT: Running analysis: OptimizationRemarkEmitterAnalysis on foo
54; CHECK-O-NEXT: Running analysis: AAManager on foo
55; CHECK-O-NEXT: Running analysis: OuterAnalysisManagerProxy
56; CHECK-O-NEXT: Finished {{.*}}Function pass manager run.
57; CHECK-O-NEXT: Running pass: SampleProfileLoaderPass
58; CHECK-O-NEXT: Running analysis: ProfileSummaryAnalysis
59; CHECK-O-NEXT: Running analysis: CallGraphAnalysis
60; CHECK-O-NEXT: Running pass: RequireAnalysisPass<{{.*}}ProfileSummaryAnalysis
61; CHECK-O-NEXT: Running pass: PGOIndirectCallPromotion
62; CHECK-O-NEXT: Running pass: IPSCCPPass
63; CHECK-O-NEXT: Running pass: CalledValuePropagationPass
64; CHECK-O-NEXT: Running pass: GlobalOptPass
65; CHECK-O-NEXT: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PromotePass>
66; CHECK-O-NEXT: Running pass: DeadArgumentEliminationPass
67; CHECK-O-NEXT: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PassManager{{.*}}>
68; CHECK-O-NEXT: Starting {{.*}}Function pass manager run.
69; CHECK-O-NEXT: Running pass: InstCombinePass
70; CHECK-O-NEXT: Running analysis: BlockFrequencyAnalysis on foo
71; These next two can appear in any order since they are accessed as parameters
72; on the same call to BlockFrequencyInfo::calculate.
73; CHECK-O-DAG: Running analysis: BranchProbabilityAnalysis on foo
74; CHECK-O-DAG: Running analysis: LoopAnalysis on foo
75; CHECK-O-NEXT: Running pass: SimplifyCFGPass on foo
76; CHECK-O-NEXT: Finished {{.*}}Function pass manager run
77; CHECK-O-NEXT: Running pass: RequireAnalysisPass<{{.*}}GlobalsAA
78; CHECK-O-NEXT: Running analysis: GlobalsAA
79; CHECK-O-NEXT: Running pass: RequireAnalysisPass<{{.*}}ProfileSummaryAnalysis
80; CHECK-O-NEXT: Running pass: ModuleToPostOrderCGSCCPassAdaptor<{{.*}}LazyCallGraph{{.*}}>
81; CHECK-O-NEXT: Running analysis: InnerAnalysisManagerProxy
82; CHECK-O-NEXT: Running analysis: LazyCallGraphAnalysis
83; CHECK-O-NEXT: Running analysis: FunctionAnalysisManagerCGSCCProxy
84; CHECK-O-NEXT: Running analysis: PassInstrumentationAnalysis
85; CHECK-O-NEXT: Running analysis: OuterAnalysisManagerProxy<{{.*}}LazyCallGraph::SCC{{.*}}>
86; CHECK-O-NEXT: Starting CGSCC pass manager run.
87; CHECK-O-NEXT: Running pass: InlinerPass
88; CHECK-O-NEXT: Running pass: PostOrderFunctionAttrsPass
89; CHECK-O3-NEXT: Running pass: ArgumentPromotionPass
90; CHECK-O2-NEXT: Running pass: OpenMPOptPass
91; CHECK-O3-NEXT: Running pass: OpenMPOptPass
92; CHECK-O-NEXT: Running pass: CGSCCToFunctionPassAdaptor<{{.*}}PassManager{{.*}}>
93; CHECK-O-NEXT: Starting {{.*}}Function pass manager run.
94; CHECK-O-NEXT: Running pass: SROA
95; CHECK-O-NEXT: Running pass: EarlyCSEPass
96; CHECK-O-NEXT: Running analysis: MemorySSAAnalysis
97; CHECK-O23SZ-NEXT: Running pass: SpeculativeExecutionPass
98; CHECK-O23SZ-NEXT: Running pass: JumpThreadingPass
99; CHECK-O23SZ-NEXT: Running analysis: LazyValueAnalysis
100; CHECK-O23SZ-NEXT: Running pass: CorrelatedValuePropagationPass
101; CHECK-O-NEXT: Running pass: SimplifyCFGPass
102; CHECK-O3-NEXT: Running pass: AggressiveInstCombinePass
103; CHECK-O-NEXT: Running pass: InstCombinePass
104; CHECK-O1-NEXT: Running pass: LibCallsShrinkWrapPass
105; CHECK-O2-NEXT: Running pass: LibCallsShrinkWrapPass
106; CHECK-O3-NEXT: Running pass: LibCallsShrinkWrapPass
107; CHECK-O23SZ-NEXT: Running pass: TailCallElimPass
108; CHECK-O-NEXT: Running pass: SimplifyCFGPass
109; CHECK-O-NEXT: Running pass: ReassociatePass
110; CHECK-O-NEXT: Running pass: RequireAnalysisPass<{{.*}}OptimizationRemarkEmitterAnalysis
111; CHECK-O-NEXT: Running pass: FunctionToLoopPassAdaptor<{{.*}}LoopStandardAnalysisResults{{.*}}>
112; CHECK-O-NEXT: Starting {{.*}}Function pass manager run
113; CHECK-O-NEXT: Running pass: LoopSimplifyPass
114; CHECK-O-NEXT: Running pass: LCSSAPass
115; CHECK-O-NEXT: Finished {{.*}}Function pass manager run
116; CHECK-O-NEXT: Running analysis: ScalarEvolutionAnalysis
117; CHECK-O-NEXT: Running analysis: InnerAnalysisManagerProxy
118; CHECK-O-NEXT: Starting Loop pass manager run.
119; CHECK-O-NEXT: Running analysis: PassInstrumentationAnalysis
120; CHECK-O-NEXT: Running pass: LoopInstSimplifyPass
121; CHECK-O-NEXT: Running pass: LoopSimplifyCFGPass
122; CHECK-O-NEXT: Running pass: LoopRotatePass
123; CHECK-O-NEXT: Running pass: LICM
124; CHECK-O-NEXT: Running pass: SimpleLoopUnswitchPass
125; CHECK-O-NEXT: Finished Loop pass manager run.
126; CHECK-O-NEXT: Running pass: SimplifyCFGPass
127; CHECK-O-NEXT: Running pass: InstCombinePass
128; CHECK-O-NEXT: Running pass: FunctionToLoopPassAdaptor<{{.*}}LoopStandardAnalysisResults{{.*}}>
129; CHECK-O-NEXT: Starting {{.*}}Function pass manager run
130; CHECK-O-NEXT: Running pass: LoopSimplifyPass
131; CHECK-O-NEXT: Running pass: LCSSAPass
132; CHECK-O-NEXT: Finished {{.*}}Function pass manager run
133; CHECK-O-NEXT: Starting Loop pass manager run.
134; CHECK-O-NEXT: Running pass: IndVarSimplifyPass
135; CHECK-O-NEXT: Running pass: LoopIdiomRecognizePass
136; CHECK-O-NEXT: Running pass: LoopDeletionPass
137; CHECK-O-NEXT: Running pass: LoopFullUnrollPass
138; CHECK-O-NEXT: Finished Loop pass manager run.
139; CHECK-O-NEXT: Running pass: SROA on foo
140; CHECK-Os-NEXT: Running pass: MergedLoadStoreMotionPass
141; CHECK-Os-NEXT: Running pass: GVN
142; CHECK-Os-NEXT: Running analysis: MemoryDependenceAnalysis
143; CHECK-Os-NEXT: Running analysis: PhiValuesAnalysis
144; CHECK-Oz-NEXT: Running pass: MergedLoadStoreMotionPass
145; CHECK-Oz-NEXT: Running pass: GVN
146; CHECK-Oz-NEXT: Running analysis: MemoryDependenceAnalysis
147; CHECK-Oz-NEXT: Running analysis: PhiValuesAnalysis
148; CHECK-O2-NEXT: Running pass: MergedLoadStoreMotionPass
149; CHECK-O2-NEXT: Running pass: GVN
150; CHECK-O2-NEXT: Running analysis: MemoryDependenceAnalysis
151; CHECK-O2-NEXT: Running analysis: PhiValuesAnalysis
152; CHECK-O3-NEXT: Running pass: MergedLoadStoreMotionPass
153; CHECK-O3-NEXT: Running pass: GVN
154; CHECK-O3-NEXT: Running analysis: MemoryDependenceAnalysis
155; CHECK-O3-NEXT: Running analysis: PhiValuesAnalysis
156; CHECK-O-NEXT: Running pass: MemCpyOptPass
157; CHECK-O1-NEXT: Running analysis: MemoryDependenceAnalysis
158; CHECK-O1-NEXT: Running analysis: PhiValuesAnalysis
159; CHECK-O-NEXT: Running pass: SCCPPass
160; CHECK-O-NEXT: Running pass: BDCEPass
161; CHECK-O-NEXT: Running analysis: DemandedBitsAnalysis
162; CHECK-O-NEXT: Running pass: InstCombinePass
163; CHECK-O23SZ-NEXT: Running pass: JumpThreadingPass
164; CHECK-O23SZ-NEXT: Running pass: CorrelatedValuePropagationPass
165; CHECK-O23SZ-NEXT: Running pass: DSEPass
166; CHECK-O23SZ-NEXT: Running pass: FunctionToLoopPassAdaptor<{{.*}}LICMPass{{.*}}>
167; CHECK-O23SZ-NEXT: Starting {{.*}}Function pass manager run
168; CHECK-O23SZ-NEXT: Running pass: LoopSimplifyPass
169; CHECK-O23SZ-NEXT: Running pass: LCSSAPass
170; CHECK-O23SZ-NEXT: Finished {{.*}}Function pass manager run
171; CHECK-O-NEXT: Running pass: ADCEPass
172; CHECK-O-NEXT: Running analysis: PostDominatorTreeAnalysis
173; CHECK-O-NEXT: Running pass: SimplifyCFGPass
174; CHECK-O-NEXT: Running pass: InstCombinePass
175; CHECK-O3-NEXT: Running pass: ControlHeightReductionPass on foo
176; CHECK-O3-NEXT: Running analysis: RegionInfoAnalysis on foo
177; CHECK-O3-NEXT: Running analysis: DominanceFrontierAnalysis on foo
178; CHECK-O-NEXT: Finished {{.*}}Function pass manager run.
179; CHECK-O-NEXT: Finished CGSCC pass manager run.
180; CHECK-O-NEXT: Finished {{.*}}Module pass manager run.
181; CHECK-O-NEXT: Running pass: PassManager<{{.*}}Module{{.*}}>
182; CHECK-O-NEXT: Starting {{.*}}Module pass manager run.
183; CHECK-O-NEXT: Running pass: GlobalOptPass
184; CHECK-O-NEXT: Running pass: GlobalDCEPass
185; CHECK-O-NEXT: Running pass: EliminateAvailableExternallyPass
186; CHECK-O-NEXT: Running pass: ReversePostOrderFunctionAttrsPass
187; CHECK-O-NEXT: Running pass: RequireAnalysisPass<{{.*}}GlobalsAA
188; CHECK-O-NEXT: Running pass: ModuleToFunctionPassAdaptor<{{.*}}PassManager{{.*}}>
189; CHECK-O-NEXT: Starting {{.*}}Function pass manager run.
190; CHECK-O-NEXT: Running pass: Float2IntPass
191; CHECK-O-NEXT: Running pass: LowerConstantIntrinsicsPass
192; CHECK-EXT: Running pass: {{.*}}::Bye
193; CHECK-O-NEXT: Running pass: FunctionToLoopPassAdaptor<{{.*}}LoopRotatePass
194; CHECK-O-NEXT: Starting {{.*}}Function pass manager run
195; CHECK-O-NEXT: Running pass: LoopSimplifyPass
196; CHECK-O-NEXT: Running pass: LCSSAPass
197; CHECK-O-NEXT: Finished {{.*}}Function pass manager run
198; CHECK-O-NEXT: Running pass: LoopDistributePass
199; CHECK-O-NEXT: Running pass: LoopVectorizePass
200; CHECK-O-NEXT: Running pass: VectorCombinePass
201; CHECK-O-NEXT: Running pass: EarlyCSEPass
202; CHECK-O-NEXT: Running pass: LoopLoadEliminationPass
203; CHECK-O-NEXT: Running analysis: LoopAccessAnalysis
204; CHECK-O-NEXT: Running pass: InstCombinePass
205; CHECK-O-NEXT: Running pass: SimplifyCFGPass
206; CHECK-O2-NEXT: Running pass: SLPVectorizerPass
207; CHECK-O3-NEXT: Running pass: SLPVectorizerPass
208; CHECK-Os-NEXT: Running pass: SLPVectorizerPass
209; CHECK-O-NEXT: Running pass: InstCombinePass
210; CHECK-O-NEXT: Running pass: LoopUnrollPass
211; CHECK-O-NEXT: Running pass: WarnMissedTransformationsPass
212; CHECK-O-NEXT: Running pass: InstCombinePass
213; CHECK-O-NEXT: Running pass: RequireAnalysisPass<{{.*}}OptimizationRemarkEmitterAnalysis
214; CHECK-O-NEXT: Running pass: FunctionToLoopPassAdaptor<{{.*}}LICMPass
215; CHECK-O-NEXT: Starting {{.*}}Function pass manager run
216; CHECK-O-NEXT: Running pass: LoopSimplifyPass
217; CHECK-O-NEXT: Running pass: LCSSAPass
218; CHECK-O-NEXT: Finished {{.*}}Function pass manager run
219; CHECK-O-NEXT: Running pass: AlignmentFromAssumptionsPass
220; CHECK-O-NEXT: Running pass: LoopSinkPass
221; CHECK-O-NEXT: Running pass: InstSimplifyPass
222; CHECK-O-NEXT: Running pass: DivRemPairsPass
223; CHECK-O-NEXT: Running pass: SimplifyCFGPass
224; CHECK-O-NEXT: Running pass: SpeculateAroundPHIsPass
225; CHECK-O-NEXT: Finished {{.*}}Function pass manager run.
226; CHECK-O-NEXT: Running pass: CGProfilePass
227; CHECK-O-NEXT: Running pass: GlobalDCEPass
228; CHECK-O-NEXT: Running pass: ConstantMergePass
229; CHECK-O-NEXT: Finished {{.*}}Module pass manager run.
230; CHECK-O-NEXT: Finished {{.*}}Module pass manager run.
231; CHECK-O-NEXT: Running pass: PrintModulePass
232
233; Make sure we get the IR back out without changes when we print the module.
234; CHECK-O-LABEL: define void @foo(i32 %n) local_unnamed_addr
235; CHECK-O-NEXT: entry:
236; CHECK-O-NEXT:   br label %loop
237; CHECK-O:      loop:
238; CHECK-O-NEXT:   %iv = phi i32 [ 0, %entry ], [ %iv.next, %loop ]
239; CHECK-O-NEXT:   %iv.next = add i32 %iv, 1
240; CHECK-O-NEXT:   tail call void @bar()
241; CHECK-O-NEXT:   %cmp = icmp eq i32 %iv, %n
242; CHECK-O-NEXT:   br i1 %cmp, label %exit, label %loop
243; CHECK-O:      exit:
244; CHECK-O-NEXT:   ret void
245; CHECK-O-NEXT: }
246;
247; Ignore a bunch of intervening metadata containing profile data.
248;
249; CHECK-O: Finished {{.*}}Module pass manager run.
250
251declare void @bar() local_unnamed_addr
252
253define void @foo(i32 %n) local_unnamed_addr {
254entry:
255  br label %loop
256loop:
257  %iv = phi i32 [ 0, %entry ], [ %iv.next, %loop ]
258  %iv.next = add i32 %iv, 1
259  tail call void @bar()
260  %cmp = icmp eq i32 %iv, %n
261  br i1 %cmp, label %exit, label %loop
262exit:
263  ret void
264}
265