blob: b844db271170c6a2e530d3884cb986dd9cc3401f [file] [log] [blame]
Adam Nemetaad81602016-07-15 17:23:20 +00001//===- OptimizationDiagnosticInfo.cpp - Optimization 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//
10// Optimization diagnostic interfaces. It's packaged as an analysis pass so
11// that by using this service passes become dependent on BFI as well. BFI is
12// used to compute the "hotness" of the diagnostic message.
13//===----------------------------------------------------------------------===//
14
15#include "llvm/Analysis/OptimizationDiagnosticInfo.h"
16#include "llvm/Analysis/LazyBlockFrequencyInfo.h"
17#include "llvm/Analysis/LoopInfo.h"
18#include "llvm/IR/DiagnosticInfo.h"
19#include "llvm/IR/LLVMContext.h"
20
21using namespace llvm;
22
Adam Nemetaad81602016-07-15 17:23:20 +000023Optional<uint64_t> OptimizationRemarkEmitter::computeHotness(Value *V) {
24 if (!BFI)
25 return None;
26
27 return BFI->getBlockProfileCount(cast<BasicBlock>(V));
28}
29
30void OptimizationRemarkEmitter::emitOptimizationRemarkMissed(
31 const char *PassName, const DebugLoc &DLoc, Value *V, const Twine &Msg) {
32 LLVMContext &Ctx = F->getContext();
33 Ctx.diagnose(DiagnosticInfoOptimizationRemarkMissed(PassName, *F, DLoc, Msg,
34 computeHotness(V)));
35}
36
37void OptimizationRemarkEmitter::emitOptimizationRemarkMissed(
38 const char *PassName, Loop *L, const Twine &Msg) {
39 emitOptimizationRemarkMissed(PassName, L->getStartLoc(), L->getHeader(), Msg);
40}
41
Adam Nemet79ac42a2016-07-18 16:29:21 +000042OptimizationRemarkEmitterWrapperPass::OptimizationRemarkEmitterWrapperPass()
43 : FunctionPass(ID) {
44 initializeOptimizationRemarkEmitterWrapperPassPass(
45 *PassRegistry::getPassRegistry());
46}
47
48bool OptimizationRemarkEmitterWrapperPass::runOnFunction(Function &Fn) {
49 BlockFrequencyInfo *BFI;
Adam Nemetaad81602016-07-15 17:23:20 +000050
51 if (Fn.getContext().getDiagnosticHotnessRequested())
52 BFI = &getAnalysis<LazyBlockFrequencyInfoPass>().getBFI();
53 else
54 BFI = nullptr;
55
Adam Nemet79ac42a2016-07-18 16:29:21 +000056 ORE = llvm::make_unique<OptimizationRemarkEmitter>(&Fn, BFI);
Adam Nemetaad81602016-07-15 17:23:20 +000057 return false;
58}
59
Adam Nemet79ac42a2016-07-18 16:29:21 +000060void OptimizationRemarkEmitterWrapperPass::getAnalysisUsage(
61 AnalysisUsage &AU) const {
Adam Nemetaad81602016-07-15 17:23:20 +000062 LazyBlockFrequencyInfoPass::getLazyBFIAnalysisUsage(AU);
63 AU.setPreservesAll();
64}
65
Adam Nemet79ac42a2016-07-18 16:29:21 +000066char OptimizationRemarkEmitterAnalysis::PassID;
67
68OptimizationRemarkEmitter
Adam Nemet78d10912016-07-20 21:44:18 +000069OptimizationRemarkEmitterAnalysis::run(Function &F,
70 AnalysisManager<Function> &AM) {
Adam Nemet79ac42a2016-07-18 16:29:21 +000071 BlockFrequencyInfo *BFI;
72
73 if (F.getContext().getDiagnosticHotnessRequested())
74 BFI = &AM.getResult<BlockFrequencyAnalysis>(F);
75 else
76 BFI = nullptr;
77
78 return OptimizationRemarkEmitter(&F, BFI);
79}
80
81char OptimizationRemarkEmitterWrapperPass::ID = 0;
Adam Nemetaad81602016-07-15 17:23:20 +000082static const char ore_name[] = "Optimization Remark Emitter";
83#define ORE_NAME "opt-remark-emitter"
84
Adam Nemet79ac42a2016-07-18 16:29:21 +000085INITIALIZE_PASS_BEGIN(OptimizationRemarkEmitterWrapperPass, ORE_NAME, ore_name,
86 false, true)
Adam Nemetaad81602016-07-15 17:23:20 +000087INITIALIZE_PASS_DEPENDENCY(LazyBFIPass)
Adam Nemet79ac42a2016-07-18 16:29:21 +000088INITIALIZE_PASS_END(OptimizationRemarkEmitterWrapperPass, ORE_NAME, ore_name,
89 false, true)