26#include "llvm/Config/llvm-config.h"
62#if !defined(_MSC_VER) && !defined(__MINGW32__)
71#define DEBUG_TYPE "thinlto"
103 " to save optimized bitcode\n");
108 ArrayRef<std::unique_ptr<GlobalValueSummary>> GVSummaryList) {
111 GVSummaryList, [](
const std::unique_ptr<GlobalValueSummary> &Summary) {
112 auto Linkage = Summary->linkage();
116 if (StrongDefForLinker != GVSummaryList.end())
117 return StrongDefForLinker->get();
121 GVSummaryList, [](
const std::unique_ptr<GlobalValueSummary> &Summary) {
122 auto Linkage = Summary->linkage();
126 if (FirstDefForLinker == GVSummaryList.end())
128 return FirstDefForLinker->get();
137 auto HasMultipleCopies =
139 return GVSummaryList.size() > 1;
142 for (
auto &
I : Index) {
143 if (HasMultipleCopies(
I.second.getSummaryList()))
144 PrevailingCopy[
I.first] =
152 for (
auto &M : Modules) {
153 LLVM_DEBUG(
dbgs() <<
"Adding module " << M->getName() <<
" to ModuleMap\n");
155 "Expect unique Buffer Identifier");
156 ModuleMap[M->getName()] = M.get();
162 bool ClearDSOLocalOnDeclarations) {
172 : DiagnosticInfo(
DK_Linker, Severity), Msg(DiagMsg) {}
173 void print(DiagnosticPrinter &DP)
const override { DP << Msg; }
179 bool BrokenDebugInfo =
false;
182 if (BrokenDebugInfo) {
184 "Invalid debug info found, debug info will be stripped",
DS_Warning));
193 auto &
Mod =
Input->getSingleBitcodeModule();
196 Lazy ?
Mod.getLazyModule(Context,
198 :
Mod.parseModule(Context);
201 SMDiagnostic Err = SMDiagnostic(Mod.getModuleIdentifier(),
202 SourceMgr::DK_Error, EIB.message());
203 Err.print(
"ThinLTO", errs());
209 return std::move(*ModuleOrErr);
216 bool ClearDSOLocalOnDeclarations) {
217 auto Loader = [&](
StringRef Identifier) {
218 auto &
Input = ModuleMap[Identifier];
227 SMDiagnostic Err = SMDiagnostic(TheModule.getModuleIdentifier(),
228 SourceMgr::DK_Error, EIB.message());
229 Err.print(
"ThinLTO", errs());
238 unsigned OptLevel,
bool Freestanding,
240 std::optional<PGOOptions> PGOOpt;
269 std::unique_ptr<TargetLibraryInfoImpl> TLII(
272 TLII->disableAllFunctions();
276 PB.registerModuleAnalyses(
MAM);
277 PB.registerCGSCCAnalyses(
CGAM);
278 PB.registerFunctionAnalyses(
FAM);
279 PB.registerLoopAnalyses(
LAM);
303 MPM.
addPass(
PB.buildThinLTODefaultPipeline(OL, Index));
311 Triple TT(File.getTargetTriple());
315 for (
const auto &Sym : File.symbols())
316 if (Sym.isUsed() || Sym.isLibcall(TLI, Libcalls))
328 for (
const auto &Sym : File.symbols()) {
329 if (PreservedSymbols.
count(Sym.getName()) && !Sym.getIRName().empty())
339 const Triple &TheTriple) {
342 GUIDPreservedSymbols);
343 return GUIDPreservedSymbols;
363 return std::make_unique<SmallVectorMemoryBuffer>(
369class ModuleCacheEntry {
370 SmallString<128> EntryPath;
377 StringRef CachePath,
const ModuleSummaryIndex &Index, StringRef ModuleID,
378 const FunctionImporter::ImportMapTy &ImportList,
380 const std::map<GlobalValue::GUID, GlobalValue::LinkageTypes> &ResolvedODR,
382 bool Freestanding,
const TargetMachineBuilder &TMBuilder) {
383 if (CachePath.
empty())
386 if (!
Index.modulePaths().count(ModuleID))
391 [](uint32_t V) { return V == 0; }))
395 llvm::lto::Config Conf;
405 ResolvedODR, DefinedGVSummaries);
413 StringRef getEntryPath() {
return EntryPath; }
416 ErrorOr<std::unique_ptr<MemoryBuffer>> tryLoadingBuffer() {
417 if (EntryPath.empty())
418 return std::error_code();
419 SmallString<64> ResultPath;
425 *FDOrErr, EntryPath, -1,
false);
431 void write(
const MemoryBuffer &OutputBuffer) {
432 if (EntryPath.empty())
436 EntryPath, [&OutputBuffer](llvm::raw_ostream &OS) ->
llvm::Error {
447static std::unique_ptr<MemoryBuffer>
455 bool DisableCodeGen,
StringRef SaveTempsDir,
456 bool Freestanding,
unsigned OptLevel,
unsigned count,
457 bool DebugPassManager) {
459 bool SingleModule = (ModuleMap.
size() == 1);
463 bool ClearDSOLocalOnDeclarations =
469 promoteModule(TheModule, Index, ClearDSOLocalOnDeclarations);
480 if (!ExportList.
empty() || !GUIDPreservedSymbols.
empty()) {
490 ClearDSOLocalOnDeclarations);
501 optimizeModule(TheModule, TM, OptLevel, Freestanding, DebugPassManager,
506 if (DisableCodeGen) {
515 return std::make_unique<SmallVectorMemoryBuffer>(
529 StringMap<std::map<GlobalValue::GUID, GlobalValue::LinkageTypes>>
536 const auto &Prevailing = PrevailingCopy.
find(GUID);
538 if (Prevailing == PrevailingCopy.
end())
540 return Prevailing->second == S;
543 auto recordNewLinkage = [&](
StringRef ModuleIdentifier,
546 ResolvedODR[ModuleIdentifier][GUID] = NewLinkage;
552 GUIDPreservedSymbols);
557 const Triple &TheTriple) {
558 if (TMBuilder.
MCpu.empty())
560 TMBuilder.
TheTriple = std::move(TheTriple);
569 toString(InputOrError.takeError()));
571 auto TripleStr = (*InputOrError)->getTargetTriple();
572 Triple TheTriple(TripleStr);
576 else if (TMBuilder.TheTriple != TheTriple) {
577 if (!TMBuilder.TheTriple.isCompatibleWith(TheTriple))
583 Modules.emplace_back(std::move(*InputOrError));
587 PreservedSymbols.insert(Name);
594 PreservedSymbols.insert(Name);
608 std::string FeatureStr = Features.
getString();
610 std::unique_ptr<TargetMachine> TM(
613 assert(TM &&
"Cannot create target machine");
623 std::unique_ptr<ModuleSummaryIndex> CombinedIndex =
624 std::make_unique<ModuleSummaryIndex>(
false);
625 for (
auto &
Mod : Modules) {
626 auto &M =
Mod->getSingleBitcodeModule();
627 if (
Error Err = M.readSummary(*CombinedIndex,
Mod->getName())) {
630 std::move(Err),
errs(),
631 "error: can't create module summary index for buffer: ");
635 return CombinedIndex;
646 : ExportLists(ExportLists), GUIDPreservedSymbols(GUIDPreservedSymbols) {}
649 const auto &ExportList = ExportLists.
find(ModuleIdentifier);
650 return (ExportList != ExportLists.
end() && ExportList->second.
count(VI)) ||
651 GUIDPreservedSymbols.
count(VI.getGUID());
656 const DenseMap<GlobalValue::GUID, const GlobalValueSummary *> &PrevailingCopy;
657 IsPrevailing(
const DenseMap<GlobalValue::GUID, const GlobalValueSummary *>
659 : PrevailingCopy(PrevailingCopy) {}
662 const auto &Prevailing = PrevailingCopy.
find(GUID);
664 if (Prevailing == PrevailingCopy.
end())
666 return Prevailing->second == S;
690 auto ModuleCount = Index.modulePaths().size();
695 Index.collectDefinedGVSummariesPerModule(ModuleToDefinedGVSummaries);
715 IsPrevailing(PrevailingCopy), ImportLists,
724 ModuleToDefinedGVSummaries[ModuleIdentifier],
730 Index, IsExported(ExportLists, GUIDPreservedSymbols),
731 IsPrevailing(PrevailingCopy));
744 auto ModuleCount = Index.modulePaths().size();
748 Index.collectDefinedGVSummariesPerModule(ModuleToDefinedGVSummaries);
767 IsPrevailing(PrevailingCopy), ImportLists,
783 auto ModuleCount = Index.modulePaths().size();
788 Index.collectDefinedGVSummariesPerModule(ModuleToDefinedGVSummaries);
807 IsPrevailing(PrevailingCopy), ImportLists,
811 ModuleIdentifier, ModuleToDefinedGVSummaries,
812 ImportLists[ModuleIdentifier], ModuleToSummariesForIndex, DecSummaries);
821 auto ModuleCount = Index.modulePaths().size();
826 Index.collectDefinedGVSummariesPerModule(ModuleToDefinedGVSummaries);
845 IsPrevailing(PrevailingCopy), ImportLists,
854 ModuleIdentifier, ModuleToDefinedGVSummaries,
855 ImportLists[ModuleIdentifier], ModuleToSummariesForIndex, DecSummaries);
858 ModuleToSummariesForIndex))
860 " to save imports lists\n");
871 auto ModuleCount = Index.modulePaths().size();
875 auto GUIDPreservedSymbols =
882 Index.collectDefinedGVSummariesPerModule(ModuleToDefinedGVSummaries);
895 IsPrevailing(PrevailingCopy), ImportLists,
897 auto &ExportList = ExportLists[ModuleIdentifier];
901 if (ExportList.
empty() && GUIDPreservedSymbols.
empty())
912 Index, IsExported(ExportLists, GUIDPreservedSymbols),
913 IsPrevailing(PrevailingCopy));
920 ModuleToDefinedGVSummaries[ModuleIdentifier],
924 ModuleToDefinedGVSummaries[ModuleIdentifier]);
934 optimizeModule(TheModule, *TMBuilder.create(), OptLevel, Freestanding,
935 DebugPassManager,
nullptr);
944 auto ArchName = TMBuilder.TheTriple.getArchName();
947 Twine(
count) +
"." + ArchName +
".thinlto.o");
953 if (!CacheEntryPath.
empty()) {
957 return std::string(OutputPath);
961 return std::string(OutputPath);
965 errs() <<
"remark: can't link or copy from cached entry '" << CacheEntryPath
966 <<
"' to '" << OutputPath <<
"'\n";
974 return std::string(OutputPath);
985 assert(ProducedBinaries.empty() &&
"The generator should not be reused");
986 if (SavedObjectsDirectoryPath.empty())
987 ProducedBinaries.resize(Modules.size());
994 ProducedBinaryFiles.resize(Modules.size());
1001 for (
auto &
Mod : Modules) {
1012 if (SavedObjectsDirectoryPath.empty())
1015 ProducedBinaryFiles[
count] =
1027 if (!SaveTempsDir.empty()) {
1028 auto SaveTempPath = SaveTempsDir +
"index.bc";
1033 " to save optimized bitcode\n");
1040 auto ModuleCount = Modules.size();
1044 Index->collectDefinedGVSummariesPerModule(ModuleToDefinedGVSummaries);
1049 for (
const auto &M : Modules)
1051 GUIDPreservedSymbols);
1054 for (
const auto &M : Modules)
1064 Index->setWithWholeProgramVisibility();
1077 std::map<ValueInfo, std::vector<VTableSlotSummary>> LocalWPDTargetsMap;
1078 std::set<GlobalValue::GUID> ExportedGUIDs;
1091 IsPrevailing(PrevailingCopy), ImportLists,
1109 IsExported(ExportLists, GUIDPreservedSymbols),
1110 LocalWPDTargetsMap);
1112 *Index, IsExported(ExportLists, GUIDPreservedSymbols),
1113 IsPrevailing(PrevailingCopy));
1120 for (
auto &
Module : Modules) {
1122 ExportLists[ModuleIdentifier];
1123 ImportLists[ModuleIdentifier];
1124 ResolvedODR[ModuleIdentifier];
1125 ModuleToDefinedGVSummaries[ModuleIdentifier];
1128 std::vector<BitcodeModule *> ModulesVec;
1129 ModulesVec.reserve(Modules.size());
1130 for (
auto &
Mod : Modules)
1131 ModulesVec.push_back(&
Mod->getSingleBitcodeModule());
1137 TimeTraceScopeExit.release();
1142 for (
auto IndexCount : ModulesOrdering) {
1143 auto &
Mod = Modules[IndexCount];
1145 auto ModuleIdentifier =
Mod->getName();
1146 auto &ExportList = ExportLists[ModuleIdentifier];
1148 auto &DefinedGVSummaries = ModuleToDefinedGVSummaries[ModuleIdentifier];
1151 ModuleCacheEntry CacheEntry(CacheOptions.Path, *Index, ModuleIdentifier,
1152 ImportLists[ModuleIdentifier], ExportList,
1153 ResolvedODR[ModuleIdentifier],
1154 DefinedGVSummaries, OptLevel, Freestanding,
1156 auto CacheEntryPath = CacheEntry.getEntryPath();
1159 auto ErrOrBuffer = CacheEntry.tryLoadingBuffer();
1161 <<
" '" << CacheEntryPath <<
"' for buffer "
1162 <<
count <<
" " << ModuleIdentifier <<
"\n");
1166 if (SavedObjectsDirectoryPath.empty())
1167 ProducedBinaries[
count] = std::move(ErrOrBuffer.get());
1170 count, CacheEntryPath, *ErrOrBuffer.get());
1177 Context.enableDebugTypeODRUniquing();
1181 if (!DiagFileOrErr) {
1182 errs() <<
"Error: " <<
toString(DiagFileOrErr.takeError()) <<
"\n";
1194 auto &ImportList = ImportLists[ModuleIdentifier];
1197 *TheModule, *Index, ModuleMap, *TMBuilder.create(), ImportList,
1198 ExportList, GUIDPreservedSymbols,
1199 ModuleToDefinedGVSummaries[ModuleIdentifier], CacheOptions,
1200 DisableCodeGen, SaveTempsDir, Freestanding, OptLevel,
count,
1206 if (SavedObjectsDirectoryPath.empty()) {
1208 if (!CacheEntryPath.empty()) {
1215 auto ReloadedBufferOrErr = CacheEntry.tryLoadingBuffer();
1216 if (
auto EC = ReloadedBufferOrErr.getError()) {
1218 errs() <<
"remark: can't reload cached file '" << CacheEntryPath
1219 <<
"': " << EC.message() <<
"\n";
1234 pruneCache(CacheOptions.Path, CacheOptions.Policy, ProducedBinaries);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file provides a bitcode writing pass.
#define LLVM_LIFETIME_BOUND
Provides passes for computing function attributes based on interprocedural analyses.
This file implements a simple parser to decode commandline option for remarks hotness threshold that ...
This is the interface to build a ModuleSummaryIndex for a module.
CGSCCAnalysisManager CGAM
if(auto Err=PB.parsePassPipeline(MPM, Passes)) return wrap(std MPM run * Mod
FunctionAnalysisManager FAM
ModuleAnalysisManager MAM
PassInstrumentationCallbacks PIC
PassBuilder PB(Machine, PassOpts->PTO, std::nullopt, &PIC)
This header defines classes/functions to handle pass execution timing information with interfaces for...
This file defines the make_scope_exit function, which executes user-defined cleanup logic at scope ex...
This header defines a class that provides bookkeeping for all standard (i.e in-tree) pass instrumenta...
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
static void crossImportIntoModule(Module &TheModule, const ModuleSummaryIndex &Index, StringMap< lto::InputFile * > &ModuleMap, const FunctionImporter::ImportMapTy &ImportList, bool ClearDSOLocalOnDeclarations)
static void computeDeadSymbolsInIndex(ModuleSummaryIndex &Index, const DenseSet< GlobalValue::GUID > &GUIDPreservedSymbols)
static StringMap< lto::InputFile * > generateModuleMap(std::vector< std::unique_ptr< lto::InputFile > > &Modules)
static void initTMBuilder(TargetMachineBuilder &TMBuilder, const Triple &TheTriple)
static void resolvePrevailingInIndex(ModuleSummaryIndex &Index, StringMap< std::map< GlobalValue::GUID, GlobalValue::LinkageTypes > > &ResolvedODR, const DenseSet< GlobalValue::GUID > &GUIDPreservedSymbols, const DenseMap< GlobalValue::GUID, const GlobalValueSummary * > &PrevailingCopy)
Resolve prevailing symbols.
static const GlobalValueSummary * getFirstDefinitionForLinker(ArrayRef< std::unique_ptr< GlobalValueSummary > > GVSummaryList)
static void computePrevailingCopies(const ModuleSummaryIndex &Index, DenseMap< GlobalValue::GUID, const GlobalValueSummary * > &PrevailingCopy)
static void saveTempBitcode(const Module &TheModule, StringRef TempDir, unsigned count, StringRef Suffix)
static void verifyLoadedModule(Module &TheModule)
Verify the module and strip broken debug info.
static void addUsedSymbolToPreservedGUID(const lto::InputFile &File, DenseSet< GlobalValue::GUID > &PreservedGUID)
static std::unique_ptr< MemoryBuffer > ProcessThinLTOModule(Module &TheModule, ModuleSummaryIndex &Index, StringMap< lto::InputFile * > &ModuleMap, TargetMachine &TM, const FunctionImporter::ImportMapTy &ImportList, const FunctionImporter::ExportSetTy &ExportList, const DenseSet< GlobalValue::GUID > &GUIDPreservedSymbols, const GVSummaryMapTy &DefinedGlobals, const ThinLTOCodeGenerator::CachingOptions &CacheOptions, bool DisableCodeGen, StringRef SaveTempsDir, bool Freestanding, unsigned OptLevel, unsigned count, bool DebugPassManager)
static cl::opt< int > ThreadCount("threads", cl::init(0))
static std::unique_ptr< MemoryBuffer > codegenModule(Module &TheModule, TargetMachine &TM)
static void optimizeModule(Module &TheModule, TargetMachine &TM, unsigned OptLevel, bool Freestanding, bool DebugPassManager, ModuleSummaryIndex *Index)
static void computeGUIDPreservedSymbols(const lto::InputFile &File, const StringSet<> &PreservedSymbols, const Triple &TheTriple, DenseSet< GlobalValue::GUID > &GUIDs)
static std::unique_ptr< Module > loadModuleFromInput(lto::InputFile *Input, LLVMContext &Context, bool Lazy, bool IsImporting)
static void promoteModule(Module &TheModule, const ModuleSummaryIndex &Index, bool ClearDSOLocalOnDeclarations)
Represent a constant reference to an array (0 or more elements consecutively in memory),...
iterator find(const_arg_type_t< KeyT > Val)
Implements a dense probed hash-table based set.
This is the base abstract class for diagnostic reporting in the backend.
Base class for error info classes.
Lightweight error class with error context and mandatory checking.
static ErrorSuccess success()
Create a success value.
Tagged union holding either a T or a Error.
Error takeError()
Take ownership of the stored error.
reference get()
Returns a reference to the stored T value.
The map maintains the list of imports.
The function importer is automatically importing function from other modules based on the provided su...
LLVM_ABI Expected< bool > importFunctions(Module &M, const ImportMapTy &ImportList)
Import functions in Module M based on the supplied import list.
DenseSet< ValueInfo > ExportSetTy
The set contains an entry for every global value that the module exports.
Function and variable summary information to aid decisions and implementation of importing.
static LLVM_ABI GUID getGUIDAssumingExternalLinkage(StringRef GlobalName)
Return a 64-bit global unique ID constructed from the name of a global symbol.
uint64_t GUID
Declare a type to represent a global unique identifier for a global value.
static bool isAvailableExternallyLinkage(LinkageTypes Linkage)
static LLVM_ABI std::string getGlobalIdentifier(StringRef Name, GlobalValue::LinkageTypes Linkage, StringRef FileName)
Return the modified name for a global value suitable to be used as the key for a global lookup (e....
bool isWeakForLinker() const
LinkageTypes
An enumeration for the kinds of linkage for global values.
@ ExternalLinkage
Externally visible function.
This is an important class for using LLVM in a threaded context.
LLVM_ABI void diagnose(const DiagnosticInfo &DI)
Report a message to the currently installed diagnostic handler.
LLVM_ABI void setDiscardValueNames(bool Discard)
Set the Context runtime configuration to discard all value name (but GlobalValue).
This interface provides simple read-only access to a block of memory, and provides simple methods for...
static ErrorOr< std::unique_ptr< MemoryBuffer > > getOpenFile(sys::fs::file_t FD, const Twine &Filename, uint64_t FileSize, bool RequiresNullTerminator=true, bool IsVolatile=false, std::optional< Align > Alignment=std::nullopt)
Given an already-open file descriptor, read the file and return a MemoryBuffer.
StringRef getBuffer() const
Class to hold module path string table and global value map, and encapsulate methods for operating on...
A Module instance is used to store all the information related to an LLVM module.
const Triple & getTargetTriple() const
Get the target triple which is a string describing the target host.
LLVMContext & getContext() const
Get the global data context.
StringRef getName() const
Get a short "name" for the module.
const std::string & getModuleIdentifier() const
Get the module identifier which is, essentially, the name of the module.
PIELevel::Level getPIELevel() const
Returns the PIE level (small or large model)
static LLVM_ABI const OptimizationLevel O3
Optimize for fast execution as much as possible.
static LLVM_ABI const OptimizationLevel O0
Disable as many optimizations as possible.
static LLVM_ABI const OptimizationLevel O2
Optimize for fast execution as much as possible without triggering significant incremental compile ti...
static LLVM_ABI const OptimizationLevel O1
Optimize quickly without destroying debuggability.
This class provides access to building LLVM's passes.
This class manages callbacks registration, as well as provides a way for PassInstrumentation to pass ...
LLVM_ATTRIBUTE_MINSIZE std::enable_if_t<!std::is_same_v< PassT, PassManager > > addPass(PassT &&Pass)
PreservedAnalyses run(IRUnitT &IR, AnalysisManagerT &AM, ExtraArgTs... ExtraArgs)
Run all of the passes in this manager over the given unit of IR.
Tunable parameters for passes in the default pipelines.
bool SLPVectorization
Tuning option to enable/disable slp loop vectorization, set based on opt level.
bool LoopVectorization
Tuning option to enable/disable loop vectorization, set based on opt level.
Analysis providing profile information.
Instances of this class encapsulate one diagnostic report, allowing printing to a raw_ostream as a ca...
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
This class provides an interface to register all the standard pass instrumentations and manages their...
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
bool contains(StringRef Key) const
contains - Return true if the element is in the map, false otherwise.
size_type count(StringRef Key) const
count - Return 1 if the element is in the map, 0 otherwise.
Represent a constant reference to a string, i.e.
constexpr bool empty() const
Check if the string is empty.
StringSet - A wrapper for StringMap that provides set-like functionality.
Manages the enabling and disabling of subtarget specific features.
LLVM_ABI void getDefaultSubtargetFeatures(const Triple &Triple)
Adds the default features for the specified target triple.
LLVM_ABI std::string getString() const
Returns features as a string.
Analysis pass providing the TargetLibraryInfo.
Implementation of the target library information.
Provides information about what library functions are available for the current target.
Primary interface to the complete machine description for the target machine.
virtual bool addPassesToEmitFile(PassManagerBase &, raw_pwrite_stream &, raw_pwrite_stream *, CodeGenFileType, bool=true, MachineModuleInfoWrapperPass *MMIWP=nullptr)
Add passes to the specified pass manager to get the specified file emitted.
const Triple & getTargetTriple() const
Reloc::Model getRelocationModel() const
Returns the code generation relocation model.
VectorLibrary VecLib
Vector math library to use.
Target - Wrapper for Target specific information.
TargetMachine * createTargetMachine(const Triple &TT, StringRef CPU, StringRef Features, const TargetOptions &Options, std::optional< Reloc::Model > RM, std::optional< CodeModel::Model > CM=std::nullopt, CodeGenOptLevel OL=CodeGenOptLevel::Default, bool JIT=false) const
createTargetMachine - Create a target specific machine implementation for the specified Triple.
LLVM_ABI void preserveSymbol(StringRef Name)
Adds to a list of all global symbols that must exist in the final generated code.
LLVM_ABI void run()
Process all the modules that were added to the code generator in parallel.
LLVM_ABI void crossReferenceSymbol(StringRef Name)
Adds to a list of all global symbols that are cross-referenced between ThinLTO files.
LLVM_ABI void addModule(StringRef Identifier, StringRef Data)
Add given module to the code generator.
auto async(Function &&F, Args &&...ArgList)
Asynchronous submission of a task to the pool.
Triple - Helper class for working with autoconf configuration names.
bool isOSBinFormatELF() const
Tests whether the OS uses the ELF binary format.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
std::pair< iterator, bool > insert(const ValueT &V)
void insert_range(Range &&R)
size_type count(const_arg_type_t< ValueT > V) const
Return 1 if the specified key is in the set, 0 otherwise.
PassManager manages ModulePassManagers.
bool run(Module &M)
run - Execute all of the passes scheduled for execution.
A raw_ostream that writes to a file descriptor.
A raw_ostream that writes to an SmallVector or SmallString.
LLVM_ABI void optimize(Module &Module)
Perform post-importing ThinLTO optimizations.
LLVM_ABI std::unique_ptr< ModuleSummaryIndex > linkCombinedIndex()
Produce the combined summary index from all the bitcode files: "thin-link".
LLVM_ABI void crossModuleImport(Module &Module, ModuleSummaryIndex &Index, const lto::InputFile &File)
Perform cross-module importing for the module identified by ModuleIdentifier.
LLVM_ABI void emitImports(Module &Module, StringRef OutputName, ModuleSummaryIndex &Index, const lto::InputFile &File)
Compute and emit the imported files for module at ModulePath.
LLVM_ABI void internalize(Module &Module, ModuleSummaryIndex &Index, const lto::InputFile &File)
Perform internalization.
LLVM_ABI void gatherImportedSummariesForModule(Module &Module, ModuleSummaryIndex &Index, ModuleToSummariesForIndexTy &ModuleToSummariesForIndex, GVSummaryPtrSet &DecSummaries, const lto::InputFile &File)
Compute the list of summaries and the subset of declaration summaries needed for importing into modul...
LLVM_ABI void promote(Module &Module, ModuleSummaryIndex &Index, const lto::InputFile &File)
Perform promotion and renaming of exported internal functions, and additionally resolve weak and link...
LLVM_ABI std::string writeGeneratedObject(int count, StringRef CacheEntryPath, const MemoryBuffer &OutputBuffer)
Write temporary object file to SavedObjectDirectoryPath, write symlink to Cache directory if needed.
Interfaces for registering analysis passes, producing common pass manager configurations,...
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
ThinLTOCodeGeneratorImpl - Namespace used for ThinLTOCodeGenerator implementation details.
initializer< Ty > init(const Ty &Val)
LLVM_ABI StringLiteral getThinLTODefaultCPU(const Triple &TheTriple)
LLVM_ABI Expected< LLVMRemarkFileHandle > setupLLVMOptimizationRemarks(LLVMContext &Context, StringRef RemarksFilename, StringRef RemarksPasses, StringRef RemarksFormat, bool RemarksWithHotness, std::optional< uint64_t > RemarksHotnessThreshold=0, int Count=-1)
Setup optimization remarks.
LLVM_ABI std::vector< int > generateModulesOrdering(ArrayRef< BitcodeModule * > R)
Produces a container ordering for optimal multi-threaded processing.
LLVM_ABI std::error_code closeFile(file_t &F)
Close the file object.
LLVM_ABI std::error_code create_hard_link(const Twine &to, const Twine &from)
Create a hard link from from to to, or return an error.
LLVM_ABI bool exists(const basic_file_status &status)
Does file exist?
@ OF_UpdateAtime
Force files Atime to be updated on access.
LLVM_ABI std::error_code remove(const Twine &path, bool IgnoreNonExisting=true)
Remove path.
LLVM_ABI Expected< file_t > openNativeFileForRead(const Twine &Name, OpenFlags Flags=OF_None, SmallVectorImpl< char > *RealPath=nullptr)
Opens the file with the given name in a read-only mode, returning its open file descriptor.
LLVM_ABI std::error_code create_directories(const Twine &path, bool IgnoreExisting=true, perms Perms=owner_all|group_all)
Create all the non-existent directories in path.
LLVM_ABI std::error_code copy_file(const Twine &From, const Twine &To)
Copy the contents of From to To.
LLVM_ABI bool is_directory(const basic_file_status &status)
Does status represent a directory?
LLVM_ABI void append(SmallVectorImpl< char > &path, const Twine &a, const Twine &b="", const Twine &c="", const Twine &d="")
Append to path.
This is an optimization pass for GlobalISel generic memory operations.
ThreadPoolStrategy heavyweight_hardware_concurrency(unsigned ThreadCount=0)
Returns a thread strategy for tasks requiring significant memory or other resources.
LLVM_ABI void logAllUnhandledErrors(Error E, raw_ostream &OS, Twine ErrorBanner={})
Log all errors (if any) in E to OS.
cl::opt< std::string > RemarksFormat("lto-pass-remarks-format", cl::desc("The format used for serializing remarks (default: YAML)"), cl::value_desc("format"), cl::init("yaml"))
LLVM_ABI void runWholeProgramDevirtOnIndex(ModuleSummaryIndex &Summary, std::set< GlobalValue::GUID > &ExportedGUIDs, std::map< ValueInfo, std::vector< VTableSlotSummary > > &LocalWPDTargetsMap, DenseSet< StringRef > *ExternallyVisibleSymbolNamesPtr=nullptr)
Perform index-based whole program devirtualization on the Summary index.
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
Printable print(const GCNRegPressure &RP, const GCNSubtarget *ST=nullptr, unsigned DynamicVGPRBlockSize=0)
std::unordered_set< GlobalValueSummary * > GVSummaryPtrSet
A set of global value summary pointers.
cl::opt< bool > LTODiscardValueNames("lto-discard-value-names", cl::desc("Strip names from Value during LTO (other than GlobalValue)."), cl::init(false), cl::Hidden)
LLVM_ABI void WriteBitcodeToFile(const Module &M, raw_ostream &Out, bool ShouldPreserveUseListOrder=false, const ModuleSummaryIndex *Index=nullptr, bool GenerateHash=false, ModuleHash *ModHash=nullptr)
Write the specified module to the specified raw output stream.
cl::opt< std::string > RemarksPasses("lto-pass-remarks-filter", cl::desc("Only record optimization remarks from passes whose " "names match the given regular expression"), cl::value_desc("regex"))
void handleAllErrors(Error E, HandlerTs &&... Handlers)
Behaves the same as handleErrors, except that by contract all errors must be handled by the given han...
SmallVectorImpl< T >::const_pointer c_str(SmallVectorImpl< T > &str)
DenseMap< GlobalValue::GUID, GlobalValueSummary * > GVSummaryMapTy
Map of global value GUID to its summary, used to identify values defined in a particular module,...
LLVM_ABI bool thinLTOPropagateFunctionAttrs(ModuleSummaryIndex &Index, function_ref< bool(GlobalValue::GUID, const GlobalValueSummary *)> isPrevailing)
Propagate function attributes for function summaries along the index's callgraph during thinlink.
LLVM_ABI void renameModuleForThinLTO(Module &M, const ModuleSummaryIndex &Index, bool ClearDSOLocalOnDeclarations, SetVector< GlobalValue * > *GlobalsToImport=nullptr)
Perform in-place global value handling on the given Module for exported local functions renamed and p...
LLVM_ABI ModuleSummaryIndex buildModuleSummaryIndex(const Module &M, std::function< BlockFrequencyInfo *(const Function &F)> GetBFICallback, ProfileSummaryInfo *PSI, std::function< const StackSafetyInfo *(const Function &F)> GetSSICallback=[](const Function &F) -> const StackSafetyInfo *{ return nullptr;})
Direct function to compute a ModuleSummaryIndex from a given module.
LLVM_ABI void reportAndResetTimings(raw_ostream *OutStream=nullptr)
If -time-passes has been specified, report the timings immediately and then reset the timers to zero.
LLVM_ABI bool hasWholeProgramVisibility(bool WholeProgramVisibilityEnabledInLTO)
AnalysisManager< LazyCallGraph::SCC, LazyCallGraph & > CGSCCAnalysisManager
The CGSCC analysis manager.
LLVM_ABI void writeIndexToFile(const ModuleSummaryIndex &Index, raw_ostream &Out, const ModuleToSummariesForIndexTy *ModuleToSummariesForIndex=nullptr, const GVSummaryPtrSet *DecSummaries=nullptr)
Write the specified module summary index to the given raw output stream, where it will be written in ...
AnalysisManager< Loop, LoopStandardAnalysisResults & > LoopAnalysisManager
The loop analysis manager.
LLVM_ABI void ComputeCrossModuleImport(const ModuleSummaryIndex &Index, const DenseMap< StringRef, GVSummaryMapTy > &ModuleToDefinedGVSummaries, function_ref< bool(GlobalValue::GUID, const GlobalValueSummary *)> isPrevailing, FunctionImporter::ImportListsTy &ImportLists, DenseMap< StringRef, FunctionImporter::ExportSetTy > &ExportLists)
Compute all the imports and exports for every module in the Index.
LLVM_ABI void updateIndexWPDForExports(ModuleSummaryIndex &Summary, function_ref< bool(StringRef, ValueInfo)> isExported, std::map< ValueInfo, std::vector< VTableSlotSummary > > &LocalWPDTargetsMap, DenseSet< StringRef > *ExternallyVisibleSymbolNamesPtr=nullptr)
Call after cross-module importing to update the recorded single impl devirt target names for any loca...
auto formatv(bool Validate, const char *Fmt, Ts &&...Vals)
LLVM_ABI void updatePublicTypeTestCalls(Module &M, bool WholeProgramVisibilityEnabledInLTO)
cl::opt< std::string > LTOCSIRProfile("cs-profile-path", cl::desc("Context sensitive profile file path"))
PassManager< Module > ModulePassManager
Convenience typedef for a pass manager over modules.
bool timeTraceProfilerEnabled()
Is the time trace profiler enabled, i.e. initialized?
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
LLVM_ABI Error writeToOutput(StringRef OutputFileName, std::function< Error(raw_ostream &)> Write)
This helper creates an output stream and then passes it to Write.
LLVM_ABI bool AreStatisticsEnabled()
Check if statistics are enabled.
std::map< std::string, GVSummaryMapTy, std::less<> > ModuleToSummariesForIndexTy
Map of a module name to the GUIDs and summaries we will import from that module.
cl::opt< bool > RemarksWithHotness("lto-pass-remarks-with-hotness", cl::desc("With PGO, include profile count in optimization remarks"), cl::Hidden)
LLVM_ABI void timeTraceProfilerEnd()
Manually end the last time section.
cl::opt< std::string > RemarksFilename("lto-pass-remarks-output", cl::desc("Output filename for pass remarks"), cl::value_desc("filename"))
LLVM_ABI void thinLTOResolvePrevailingInIndex(const lto::Config &C, ModuleSummaryIndex &Index, function_ref< bool(GlobalValue::GUID, const GlobalValueSummary *)> isPrevailing, function_ref< void(StringRef, GlobalValue::GUID, GlobalValue::LinkageTypes)> recordNewLinkage, const DenseSet< GlobalValue::GUID > &GUIDPreservedSymbols)
Resolve linkage for prevailing symbols in the Index.
cl::opt< bool > LTORunCSIRInstr("cs-profile-generate", cl::desc("Perform context sensitive PGO instrumentation"))
LLVM_ATTRIBUTE_VISIBILITY_DEFAULT AnalysisKey InnerAnalysisManagerProxy< AnalysisManagerT, IRUnitT, ExtraArgTs... >::Key
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
LLVM_ABI bool StripDebugInfo(Module &M)
Strip debug info in the module if it exists.
@ Mod
The access may modify the value stored in memory.
FunctionAddr VTableAddr uintptr_t uintptr_t Data
LLVM_ABI void PrintStatistics()
Print statistics to the file returned by CreateInfoOutputFile().
LLVM_ABI void thinLTOInternalizeModule(Module &TheModule, const GVSummaryMapTy &DefinedGlobals)
Internalize TheModule based on the information recorded in the summaries during global summary-based ...
auto count(R &&Range, const E &Element)
Wrapper function around std::count to count the number of times an element Element occurs in the give...
SingleThreadExecutor DefaultThreadPool
LLVM_ABI void gatherImportedSummariesForModule(StringRef ModulePath, const DenseMap< StringRef, GVSummaryMapTy > &ModuleToDefinedGVSummaries, const FunctionImporter::ImportMapTy &ImportList, ModuleToSummariesForIndexTy &ModuleToSummariesForIndex, GVSummaryPtrSet &DecSummaries)
Compute the set of summaries needed for a ThinLTO backend compilation of ModulePath.
std::string toString(const APInt &I, unsigned Radix, bool Signed, bool formatAsCLiteral=false, bool UpperCase=true, bool InsertSeparators=false)
DiagnosticSeverity
Defines the different supported severity of a diagnostic.
cl::opt< std::optional< uint64_t >, false, remarks::HotnessThresholdParser > RemarksHotnessThreshold("lto-pass-remarks-hotness-threshold", cl::desc("Minimum profile count required for an " "optimization remark to be output." " Use 'auto' to apply the threshold from profile summary."), cl::value_desc("uint or 'auto'"), cl::init(0), cl::Hidden)
auto find_if(R &&Range, UnaryPredicate P)
Provide wrappers to std::find_if which take ranges instead of having to pass begin/end explicitly.
LLVM_ABI std::string computeLTOCacheKey(const lto::Config &Conf, const ModuleSummaryIndex &Index, StringRef ModuleID, const FunctionImporter::ImportMapTy &ImportList, const FunctionImporter::ExportSetTy &ExportList, const std::map< GlobalValue::GUID, GlobalValue::LinkageTypes > &ResolvedODR, const GVSummaryMapTy &DefinedGlobals, const DenseSet< GlobalValue::GUID > &CfiFunctionDefs={}, const DenseSet< GlobalValue::GUID > &CfiFunctionDecls={})
Computes a unique hash for the Module considering the current list of export/import and other global ...
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
LLVM_ABI Expected< bool > pruneCache(StringRef Path, CachePruningPolicy Policy, const std::vector< std::unique_ptr< MemoryBuffer > > &Files={})
Perform pruning using the supplied policy, returns true if pruning occurred, i.e.
LLVM_ABI std::error_code errorToErrorCode(Error Err)
Helper for converting an ECError to a std::error_code.
LLVM_ABI void computeDeadSymbolsWithConstProp(ModuleSummaryIndex &Index, const DenseSet< GlobalValue::GUID > &GUIDPreservedSymbols, function_ref< PrevailingType(GlobalValue::GUID)> isPrevailing, bool ImportEnabled)
Compute dead symbols and run constant propagation in combined index after that.
LLVM_ABI Error write(DWPWriter &Out, ArrayRef< std::string > Inputs, OnCuIndexOverflow OverflowOptValue, Dwarf64StrOffsetsPromotion StrOffsetsOptValue, raw_pwrite_stream *OS=nullptr)
LLVM_ABI Error EmitImportsFiles(StringRef ModulePath, StringRef OutputFilename, const ModuleToSummariesForIndexTy &ModuleToSummariesForIndex)
Emit into OutputFilename the files module ModulePath will import from.
LLVM_ABI bool verifyModule(const Module &M, raw_ostream *OS=nullptr, bool *BrokenDebugInfo=nullptr)
Check a module for errors.
AnalysisManager< Module > ModuleAnalysisManager
Convenience typedef for the Module analysis manager.
LLVM_ABI TimeTraceProfilerEntry * timeTraceProfilerBegin(StringRef Name, StringRef Detail)
Manually begin a time section, with the given Name and Detail.
LLVM_ABI void thinLTOInternalizeAndPromoteInIndex(ModuleSummaryIndex &Index, function_ref< bool(StringRef, ValueInfo)> isExported, function_ref< bool(GlobalValue::GUID, const GlobalValueSummary *)> isPrevailing, DenseSet< StringRef > *ExternallyVisibleSymbolNamesPtr=nullptr)
Update the linkages in the given Index to mark exported values as external and non-exported values as...
LLVM_ABI void updateVCallVisibilityInIndex(ModuleSummaryIndex &Index, bool WholeProgramVisibilityEnabledInLTO, const DenseSet< GlobalValue::GUID > &DynamicExportSymbols, const DenseSet< GlobalValue::GUID > &VisibleToRegularObjSymbols)
If whole program visibility asserted, then upgrade all public vcall visibility metadata on vtable def...
cl::opt< std::string > SampleProfileFile
LLVM_ABI void thinLTOFinalizeInModule(Module &TheModule, const GVSummaryMapTy &DefinedGlobals, bool PropagateAttrs)
Based on the information recorded in the summaries during global summary-based analysis:
A struct capturing PGO tunables.
A simple container for information about the supported runtime calls.
static LLVM_ABI const Target * lookupTarget(const Triple &TheTriple, std::string &Error)
lookupTarget - Lookup a target based on a target triple.
Helper to gather options relevant to the target machine creation.
LLVM_ABI std::unique_ptr< TargetMachine > create() const
std::optional< Reloc::Model > RelocModel
CodeGenOptLevel CGOptLevel
Struct that holds a reference to a particular GUID in a global value summary.
std::vector< std::string > MAttrs
CodeGenOptLevel CGOptLevel
std::optional< Reloc::Model > RelocModel
bool Freestanding
Flag to indicate that the optimizer should not assume builtins are present on the target.