//==- RegAllocScore.h - evaluate regalloc policy quality ----------*-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 // //===----------------------------------------------------------------------===// /// Calculate a measure of the register allocation policy quality. This is used /// to construct a reward for the training of the ML-driven allocation policy. /// Currently, the score is the sum of the machine basic block frequency-weighed /// number of loads, stores, copies, and remat instructions, each factored with /// a relative weight. //===----------------------------------------------------------------------===// #ifndef LLVM_CODEGEN_REGALLOCSCORE_H_ #define LLVM_CODEGEN_REGALLOCSCORE_H_ #include "llvm/ADT/STLFunctionalExtras.h" namespace llvm { class MachineBasicBlock; class MachineBlockFrequencyInfo; class MachineFunction; class MachineInstr; /// Regalloc score. class RegAllocScore final { … }; /// Calculate a score. When comparing 2 scores for the same function but /// different policies, the better policy would have a smaller score. /// The implementation is the overload below (which is also easily unittestable) RegAllocScore calculateRegAllocScore(const MachineFunction &MF, const MachineBlockFrequencyInfo &MBFI); /// Implementation of the above, which is also more easily unittestable. RegAllocScore calculateRegAllocScore( const MachineFunction &MF, llvm::function_ref<double(const MachineBasicBlock &)> GetBBFreq, llvm::function_ref<bool(const MachineInstr &)> IsTriviallyRematerializable); } // end namespace llvm #endif // LLVM_CODEGEN_REGALLOCSCORE_H_