LLVM 20.0.0git
PGOInstrumentation.h
Go to the documentation of this file.
1//===- Transforms/Instrumentation/PGOInstrumentation.h ----------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9/// \file
10/// This file provides the interface for IR based instrumentation passes (
11/// (profile-gen, and profile-use).
12//
13//===----------------------------------------------------------------------===//
14
15#ifndef LLVM_TRANSFORMS_INSTRUMENTATION_PGOINSTRUMENTATION_H
16#define LLVM_TRANSFORMS_INSTRUMENTATION_PGOINSTRUMENTATION_H
17
18#include "llvm/ADT/ArrayRef.h"
20#include "llvm/IR/PassManager.h"
22#include <cstdint>
23#include <string>
24
25namespace llvm {
26
27extern cl::opt<bool> DebugInfoCorrelate;
28
29class Function;
30class Instruction;
31class Module;
32
33namespace vfs {
34class FileSystem;
35} // namespace vfs
36
37/// The instrumentation (profile-instr-gen) pass for IR based PGO.
38// We use this pass to create COMDAT profile variables for context
39// sensitive PGO (CSPGO). The reason to have a pass for this is CSPGO
40// can be run after LTO/ThinLTO linking. Lld linker needs to see
41// all the COMDAT variables before linking. So we have this pass
42// always run before linking for CSPGO.
44 : public PassInfoMixin<PGOInstrumentationGenCreateVar> {
45public:
46 PGOInstrumentationGenCreateVar(std::string CSInstrName = "",
47 bool Sampling = false)
48 : CSInstrName(CSInstrName), ProfileSampling(Sampling) {}
50
51private:
52 std::string CSInstrName;
53 bool ProfileSampling;
54};
55
57/// The instrumentation (profile-instr-gen) pass for IR based PGO.
58class PGOInstrumentationGen : public PassInfoMixin<PGOInstrumentationGen> {
59public:
61 PGOInstrumentationType InstrumentationType = PGOInstrumentationType ::FDO)
62 : InstrumentationType(InstrumentationType) {}
64
65private:
66 // If this is a context sensitive instrumentation.
67 const PGOInstrumentationType InstrumentationType;
68};
69
70/// The profile annotation (profile-instr-use) pass for IR based PGO.
71class PGOInstrumentationUse : public PassInfoMixin<PGOInstrumentationUse> {
72public:
73 PGOInstrumentationUse(std::string Filename = "",
74 std::string RemappingFilename = "", bool IsCS = false,
76
78
79private:
80 std::string ProfileFileName;
81 std::string ProfileRemappingFileName;
82 // If this is a context sensitive instrumentation.
83 bool IsCS;
85};
86
87/// The indirect function call promotion pass.
88class PGOIndirectCallPromotion : public PassInfoMixin<PGOIndirectCallPromotion> {
89public:
90 PGOIndirectCallPromotion(bool IsInLTO = false, bool SamplePGO = false)
91 : InLTO(IsInLTO), SamplePGO(SamplePGO) {}
92
94
95private:
96 bool InLTO;
97 bool SamplePGO;
98};
99
100/// The profile size based optimization pass for memory intrinsics.
101class PGOMemOPSizeOpt : public PassInfoMixin<PGOMemOPSizeOpt> {
102public:
103 PGOMemOPSizeOpt() = default;
104
106};
107
109 uint64_t MaxCount);
110
112
113} // end namespace llvm
114
115#endif // LLVM_TRANSFORMS_INSTRUMENTATION_PGOINSTRUMENTATION_H
This header defines various interfaces for pass management in LLVM.
This file defines the RefCountedBase, ThreadSafeRefCountedBase, and IntrusiveRefCntPtr classes.
#define F(x, y, z)
Definition: MD5.cpp:55
Machine Check Debug Module
ModuleAnalysisManager MAM
A container for analyses that lazily runs them and caches their results.
Definition: PassManager.h:253
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition: ArrayRef.h:41
A smart pointer to a reference-counted object that inherits from RefCountedBase or ThreadSafeRefCount...
A Module instance is used to store all the information related to an LLVM module.
Definition: Module.h:65
The indirect function call promotion pass.
PreservedAnalyses run(Module &M, ModuleAnalysisManager &MAM)
PGOIndirectCallPromotion(bool IsInLTO=false, bool SamplePGO=false)
The instrumentation (profile-instr-gen) pass for IR based PGO.
PGOInstrumentationGenCreateVar(std::string CSInstrName="", bool Sampling=false)
PreservedAnalyses run(Module &M, ModuleAnalysisManager &MAM)
The instrumentation (profile-instr-gen) pass for IR based PGO.
PreservedAnalyses run(Module &M, ModuleAnalysisManager &MAM)
PGOInstrumentationGen(PGOInstrumentationType InstrumentationType=PGOInstrumentationType ::FDO)
The profile annotation (profile-instr-use) pass for IR based PGO.
PreservedAnalyses run(Module &M, ModuleAnalysisManager &MAM)
The profile size based optimization pass for memory intrinsics.
PreservedAnalyses run(Function &F, FunctionAnalysisManager &MAM)
A set of analyses that are preserved following a run of a transformation pass.
Definition: Analysis.h:111
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
void setIrrLoopHeaderMetadata(Module *M, Instruction *TI, uint64_t Count)
PGOInstrumentationType
cl::opt< bool > DebugInfoCorrelate
void setProfMetadata(Module *M, Instruction *TI, ArrayRef< uint64_t > EdgeCounts, uint64_t MaxCount)
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition: PassManager.h:69