blob: 73c3428a6e535d6846b00322eb591ad18d956955 [file] [log] [blame]
Adam Nemeta9640662017-01-25 23:20:33 +00001///===- MachineOptimizationRemarkEmitter.cpp - Opt Diagnostic -*- C++ -*---===//
2///
3/// The LLVM Compiler Infrastructure
4///
5/// This file is distributed under the University of Illinois Open Source
6/// License. See LICENSE.TXT for details.
7///
8///===---------------------------------------------------------------------===//
9/// \file
10/// Optimization diagnostic interfaces for machine passes. It's packaged as an
11/// analysis pass so that by using this service passes become dependent on MBFI
12/// as well. MBFI is used to compute the "hotness" of the diagnostic message.
13///
14///===---------------------------------------------------------------------===//
15
16#include "llvm/CodeGen/MachineOptimizationRemarkEmitter.h"
Adam Nemetbbb141c2017-02-14 17:21:09 +000017#include "llvm/CodeGen/LazyMachineBlockFrequencyInfo.h"
Ahmed Bougacha27273972017-02-23 21:05:33 +000018#include "llvm/CodeGen/MachineInstr.h"
Adam Nemeta9640662017-01-25 23:20:33 +000019#include "llvm/IR/DebugInfo.h"
20#include "llvm/IR/DiagnosticInfo.h"
21#include "llvm/IR/LLVMContext.h"
22
23using namespace llvm;
24
Ahmed Bougacha27273972017-02-23 21:05:33 +000025DiagnosticInfoMIROptimization::MachineArgument::MachineArgument(
26 StringRef MKey, const MachineInstr &MI)
27 : Argument() {
28 Key = MKey;
29
30 raw_string_ostream OS(Val);
31 MI.print(OS, /*SkipOpers=*/false, /*SkipDebugLoc=*/true);
32}
33
Adam Nemeta9640662017-01-25 23:20:33 +000034Optional<uint64_t>
35MachineOptimizationRemarkEmitter::computeHotness(const MachineBasicBlock &MBB) {
36 if (!MBFI)
37 return None;
38
39 return MBFI->getBlockProfileCount(&MBB);
40}
41
42void MachineOptimizationRemarkEmitter::computeHotness(
43 DiagnosticInfoMIROptimization &Remark) {
44 const MachineBasicBlock *MBB = Remark.getBlock();
45 if (MBB)
46 Remark.setHotness(computeHotness(*MBB));
47}
48
49void MachineOptimizationRemarkEmitter::emit(
50 DiagnosticInfoOptimizationBase &OptDiagCommon) {
51 auto &OptDiag = cast<DiagnosticInfoMIROptimization>(OptDiagCommon);
52 computeHotness(OptDiag);
53
54 LLVMContext &Ctx = MF.getFunction()->getContext();
Brian Gesiak4ef3daa2017-06-30 23:14:53 +000055
56 // If a diagnostic has a hotness value, then only emit it if its hotness
57 // meets the threshold.
58 if (OptDiag.getHotness() &&
59 *OptDiag.getHotness() < Ctx.getDiagnosticsHotnessThreshold()) {
60 return;
61 }
62
Adam Nemeta9640662017-01-25 23:20:33 +000063 yaml::Output *Out = Ctx.getDiagnosticsOutputFile();
64 if (Out) {
65 auto *P = &const_cast<DiagnosticInfoOptimizationBase &>(OptDiagCommon);
66 *Out << P;
67 }
68 // FIXME: now that IsVerbose is part of DI, filtering for this will be moved
69 // from here to clang.
70 if (!OptDiag.isVerbose() || shouldEmitVerbose())
71 Ctx.diagnose(OptDiag);
72}
73
74MachineOptimizationRemarkEmitterPass::MachineOptimizationRemarkEmitterPass()
75 : MachineFunctionPass(ID) {
76 initializeMachineOptimizationRemarkEmitterPassPass(
77 *PassRegistry::getPassRegistry());
78}
79
80bool MachineOptimizationRemarkEmitterPass::runOnMachineFunction(
81 MachineFunction &MF) {
82 MachineBlockFrequencyInfo *MBFI;
83
Brian Gesiak44e5f6c2017-06-30 18:13:59 +000084 if (MF.getFunction()->getContext().getDiagnosticsHotnessRequested())
Adam Nemetbbb141c2017-02-14 17:21:09 +000085 MBFI = &getAnalysis<LazyMachineBlockFrequencyInfoPass>().getBFI();
Adam Nemeta9640662017-01-25 23:20:33 +000086 else
87 MBFI = nullptr;
88
89 ORE = llvm::make_unique<MachineOptimizationRemarkEmitter>(MF, MBFI);
90 return false;
91}
92
93void MachineOptimizationRemarkEmitterPass::getAnalysisUsage(
94 AnalysisUsage &AU) const {
Adam Nemetb516cf32017-02-23 17:30:01 +000095 AU.addRequired<LazyMachineBlockFrequencyInfoPass>();
Adam Nemeta9640662017-01-25 23:20:33 +000096 AU.setPreservesAll();
97 MachineFunctionPass::getAnalysisUsage(AU);
98}
99
100char MachineOptimizationRemarkEmitterPass::ID = 0;
101static const char ore_name[] = "Machine Optimization Remark Emitter";
102#define ORE_NAME "machine-opt-remark-emitter"
103
104INITIALIZE_PASS_BEGIN(MachineOptimizationRemarkEmitterPass, ORE_NAME, ore_name,
105 false, true)
Adam Nemetb516cf32017-02-23 17:30:01 +0000106INITIALIZE_PASS_DEPENDENCY(LazyMachineBlockFrequencyInfoPass)
Adam Nemeta9640662017-01-25 23:20:33 +0000107INITIALIZE_PASS_END(MachineOptimizationRemarkEmitterPass, ORE_NAME, ore_name,
108 false, true)