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