blob: 52156a600791cb6871bb6ad34cedfa51574b3896 [file] [log] [blame]
//===- bolt/Passes/ReorderFunctions.h - Reorder functions -------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
#ifndef BOLT_PASSES_REORDER_FUNCTIONS_H
#define BOLT_PASSES_REORDER_FUNCTIONS_H
#include "bolt/Passes/BinaryFunctionCallGraph.h"
#include "bolt/Passes/BinaryPasses.h"
namespace llvm {
namespace bolt {
class Cluster;
/// Modify function order for streaming based on hotness.
class ReorderFunctions : public BinaryFunctionPass {
BinaryFunctionCallGraph Cg;
void reorder(std::vector<Cluster> &&Clusters,
std::map<uint64_t, BinaryFunction> &BFs);
void printStats(const std::vector<Cluster> &Clusters,
const std::vector<uint64_t> &FuncAddr);
public:
enum ReorderType : char {
RT_NONE = 0,
RT_EXEC_COUNT,
RT_HFSORT,
RT_HFSORT_PLUS,
RT_PETTIS_HANSEN,
RT_RANDOM,
RT_USER
};
explicit ReorderFunctions(const cl::opt<bool> &PrintPass)
: BinaryFunctionPass(PrintPass) {}
const char *getName() const override { return "reorder-functions"; }
void runOnFunctions(BinaryContext &BC) override;
static std::vector<std::string> readFunctionOrderFile();
};
} // namespace bolt
} // namespace llvm
#endif // BOLT_PASSES_REORDER_FUNCTIONS_H