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