xref: /src/contrib/llvm-project/llvm/lib/CodeGen/MachineFunctionAnalysis.cpp (revision 0fca6ea1d4eea4c934cfff25ac9ee8ad6fe95583)
1ac9a064cSDimitry Andric //===- MachineFunctionAnalysis.cpp ----------------------------------------===//
2ac9a064cSDimitry Andric //
3ac9a064cSDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4ac9a064cSDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
5ac9a064cSDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6ac9a064cSDimitry Andric //
7ac9a064cSDimitry Andric //===----------------------------------------------------------------------===//
8ac9a064cSDimitry Andric //
9ac9a064cSDimitry Andric // This file contains the definitions of the MachineFunctionAnalysis
10ac9a064cSDimitry Andric // members.
11ac9a064cSDimitry Andric //
12ac9a064cSDimitry Andric //===----------------------------------------------------------------------===//
13ac9a064cSDimitry Andric 
14ac9a064cSDimitry Andric #include "llvm/CodeGen/MachineFunctionAnalysis.h"
15ac9a064cSDimitry Andric #include "llvm/CodeGen/MachineFunction.h"
16ac9a064cSDimitry Andric #include "llvm/CodeGen/MachineModuleInfo.h"
17ac9a064cSDimitry Andric #include "llvm/IR/Function.h"
18ac9a064cSDimitry Andric #include "llvm/Target/TargetMachine.h"
19ac9a064cSDimitry Andric 
20ac9a064cSDimitry Andric using namespace llvm;
21ac9a064cSDimitry Andric 
22ac9a064cSDimitry Andric AnalysisKey MachineFunctionAnalysis::Key;
23ac9a064cSDimitry Andric 
invalidate(Function &,const PreservedAnalyses & PA,FunctionAnalysisManager::Invalidator &)24ac9a064cSDimitry Andric bool MachineFunctionAnalysis::Result::invalidate(
25ac9a064cSDimitry Andric     Function &, const PreservedAnalyses &PA,
26ac9a064cSDimitry Andric     FunctionAnalysisManager::Invalidator &) {
27ac9a064cSDimitry Andric   // Unless it is invalidated explicitly, it should remain preserved.
28ac9a064cSDimitry Andric   auto PAC = PA.getChecker<MachineFunctionAnalysis>();
29ac9a064cSDimitry Andric   return !PAC.preservedWhenStateless();
30ac9a064cSDimitry Andric }
31ac9a064cSDimitry Andric 
32ac9a064cSDimitry Andric MachineFunctionAnalysis::Result
run(Function & F,FunctionAnalysisManager & FAM)33ac9a064cSDimitry Andric MachineFunctionAnalysis::run(Function &F, FunctionAnalysisManager &FAM) {
34ac9a064cSDimitry Andric   auto &Context = F.getContext();
35ac9a064cSDimitry Andric   const TargetSubtargetInfo &STI = *TM->getSubtargetImpl(F);
36ac9a064cSDimitry Andric   auto &MMI = FAM.getResult<ModuleAnalysisManagerFunctionProxy>(F)
37ac9a064cSDimitry Andric                   .getCachedResult<MachineModuleAnalysis>(*F.getParent())
38ac9a064cSDimitry Andric                   ->getMMI();
39ac9a064cSDimitry Andric   auto MF = std::make_unique<MachineFunction>(
40ac9a064cSDimitry Andric       F, *TM, STI, Context.generateMachineFunctionNum(F), MMI);
41ac9a064cSDimitry Andric   MF->initTargetMachineFunctionInfo(STI);
42ac9a064cSDimitry Andric 
43ac9a064cSDimitry Andric   // MRI callback for target specific initializations.
44ac9a064cSDimitry Andric   TM->registerMachineRegisterInfoCallback(*MF);
45ac9a064cSDimitry Andric 
46ac9a064cSDimitry Andric   return Result(std::move(MF));
47ac9a064cSDimitry Andric }
48