mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 20:23:11 +01:00
13bc5fbd39
Try to appease Windows bots after r278508: http://lab.llvm.org:8011/builders/sanitizer-windows/builds/27250 http://lab.llvm.org:8011/builders/clang-x64-ninja-win7/builds/14776 llvm-svn: 278517
116 lines
3.7 KiB
C++
116 lines
3.7 KiB
C++
//===- ModuleSummaryAnalysis.h - Module summary index builder ---*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
/// \file
|
|
/// This is the interface to build a ModuleSummaryIndex for a module.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_ANALYSIS_MODULESUMMARYANALYSIS_H
|
|
#define LLVM_ANALYSIS_MODULESUMMARYANALYSIS_H
|
|
|
|
#include "llvm/ADT/STLExtras.h"
|
|
#include "llvm/IR/ModuleSummaryIndex.h"
|
|
#include "llvm/IR/PassManager.h"
|
|
#include "llvm/Pass.h"
|
|
|
|
namespace llvm {
|
|
|
|
class BlockFrequencyInfo;
|
|
|
|
/// Class to build a module summary index for the given Module, possibly from
|
|
/// a Pass.
|
|
class ModuleSummaryIndexBuilder {
|
|
/// The index being built
|
|
std::unique_ptr<ModuleSummaryIndex> Index;
|
|
/// The module for which we are building an index
|
|
const Module *M;
|
|
|
|
public:
|
|
/// Default constructor
|
|
ModuleSummaryIndexBuilder() = default;
|
|
|
|
/// Constructor that builds an index for the given Module. An optional
|
|
/// callback can be supplied to obtain the frequency info for a function.
|
|
ModuleSummaryIndexBuilder(
|
|
const Module *M,
|
|
std::function<BlockFrequencyInfo *(const Function &F)> Ftor = nullptr);
|
|
|
|
/// Get a reference to the index owned by builder
|
|
ModuleSummaryIndex &getIndex() const { return *Index; }
|
|
|
|
/// Take ownership of the built index
|
|
std::unique_ptr<ModuleSummaryIndex> takeIndex() { return std::move(Index); }
|
|
|
|
private:
|
|
/// Compute summary for given function with optional frequency information
|
|
void computeFunctionSummary(const Function &F,
|
|
BlockFrequencyInfo *BFI = nullptr);
|
|
|
|
/// Compute summary for given variable with optional frequency information
|
|
void computeVariableSummary(const GlobalVariable &V);
|
|
};
|
|
|
|
/// Analysis pass to provide the ModuleSummaryIndex object.
|
|
class ModuleSummaryIndexAnalysis
|
|
: public AnalysisInfoMixin<ModuleSummaryIndexAnalysis> {
|
|
friend AnalysisInfoMixin<ModuleSummaryIndexAnalysis>;
|
|
static char PassID;
|
|
|
|
std::unique_ptr<ModuleSummaryIndexBuilder> IndexBuilder;
|
|
|
|
public:
|
|
typedef const ModuleSummaryIndex &Result;
|
|
|
|
// FIXME: Remove these once MSVC can synthesize them.
|
|
ModuleSummaryIndexAnalysis() {}
|
|
ModuleSummaryIndexAnalysis(ModuleSummaryIndexAnalysis &&Arg)
|
|
: IndexBuilder(std::move(Arg.IndexBuilder)) {}
|
|
ModuleSummaryIndexAnalysis &operator=(ModuleSummaryIndexAnalysis &&RHS) {
|
|
IndexBuilder = std::move(RHS.IndexBuilder);
|
|
return *this;
|
|
}
|
|
|
|
const ModuleSummaryIndex &run(Module &M, ModuleAnalysisManager &AM);
|
|
};
|
|
|
|
/// Legacy wrapper pass to provide the ModuleSummaryIndex object.
|
|
class ModuleSummaryIndexWrapperPass : public ModulePass {
|
|
std::unique_ptr<ModuleSummaryIndexBuilder> IndexBuilder;
|
|
|
|
public:
|
|
static char ID;
|
|
|
|
ModuleSummaryIndexWrapperPass();
|
|
|
|
/// Get the index built by pass
|
|
ModuleSummaryIndex &getIndex() { return IndexBuilder->getIndex(); }
|
|
const ModuleSummaryIndex &getIndex() const {
|
|
return IndexBuilder->getIndex();
|
|
}
|
|
|
|
bool runOnModule(Module &M) override;
|
|
bool doFinalization(Module &M) override;
|
|
void getAnalysisUsage(AnalysisUsage &AU) const override;
|
|
};
|
|
|
|
//===--------------------------------------------------------------------===//
|
|
//
|
|
// createModuleSummaryIndexWrapperPass - This pass builds a ModuleSummaryIndex
|
|
// object for the module, to be written to bitcode or LLVM assembly.
|
|
//
|
|
ModulePass *createModuleSummaryIndexWrapperPass();
|
|
|
|
/// Returns true if \p M is eligible for ThinLTO promotion.
|
|
///
|
|
/// Currently we check if it has any any InlineASM that uses an internal symbol.
|
|
bool moduleCanBeRenamedForThinLTO(const Module &M);
|
|
}
|
|
|
|
#endif
|