blob: e2bb6f185c3bf5b76fb4e58ce3b14684a6881147 [file] [log] [blame]
David Blaikie3bbf5af2018-03-22 21:41:29 +00001#include "llvm/Transforms/IPO/SCCP.h"
Florian Hahn30522902018-08-23 11:04:00 +00002#include "llvm/Analysis/AssumptionCache.h"
David Blaikie3bbf5af2018-03-22 21:41:29 +00003#include "llvm/Analysis/TargetLibraryInfo.h"
4#include "llvm/Transforms/IPO.h"
5#include "llvm/Transforms/Scalar/SCCP.h"
6
7using namespace llvm;
8
9PreservedAnalyses IPSCCPPass::run(Module &M, ModuleAnalysisManager &AM) {
10 const DataLayout &DL = M.getDataLayout();
11 auto &TLI = AM.getResult<TargetLibraryAnalysis>(M);
Florian Hahn30522902018-08-23 11:04:00 +000012 auto &FAM = AM.getResult<FunctionAnalysisManagerModuleProxy>(M).getManager();
13 auto getPredicateInfo =
14 [&FAM](Function &F) -> std::unique_ptr<PredicateInfo> {
15 return make_unique<PredicateInfo>(F,
16 FAM.getResult<DominatorTreeAnalysis>(F),
17 FAM.getResult<AssumptionAnalysis>(F));
18 };
19
20 if (!runIPSCCP(M, DL, &TLI, getPredicateInfo))
David Blaikie3bbf5af2018-03-22 21:41:29 +000021 return PreservedAnalyses::all();
22 return PreservedAnalyses::none();
23}
24
25namespace {
26
27//===--------------------------------------------------------------------===//
28//
29/// IPSCCP Class - This class implements interprocedural Sparse Conditional
30/// Constant Propagation.
31///
32class IPSCCPLegacyPass : public ModulePass {
33public:
34 static char ID;
35
36 IPSCCPLegacyPass() : ModulePass(ID) {
37 initializeIPSCCPLegacyPassPass(*PassRegistry::getPassRegistry());
38 }
39
40 bool runOnModule(Module &M) override {
41 if (skipModule(M))
42 return false;
43 const DataLayout &DL = M.getDataLayout();
44 const TargetLibraryInfo *TLI =
45 &getAnalysis<TargetLibraryInfoWrapperPass>().getTLI();
Florian Hahn30522902018-08-23 11:04:00 +000046
47 auto getPredicateInfo =
48 [this](Function &F) -> std::unique_ptr<PredicateInfo> {
49 return make_unique<PredicateInfo>(
50 F, this->getAnalysis<DominatorTreeWrapperPass>(F).getDomTree(),
51 this->getAnalysis<AssumptionCacheTracker>().getAssumptionCache(F));
52 };
53
54 return runIPSCCP(M, DL, TLI, getPredicateInfo);
David Blaikie3bbf5af2018-03-22 21:41:29 +000055 }
56
57 void getAnalysisUsage(AnalysisUsage &AU) const override {
Florian Hahn30522902018-08-23 11:04:00 +000058 AU.addRequired<AssumptionCacheTracker>();
59 AU.addRequired<DominatorTreeWrapperPass>();
David Blaikie3bbf5af2018-03-22 21:41:29 +000060 AU.addRequired<TargetLibraryInfoWrapperPass>();
61 }
62};
63
64} // end anonymous namespace
65
66char IPSCCPLegacyPass::ID = 0;
67
68INITIALIZE_PASS_BEGIN(IPSCCPLegacyPass, "ipsccp",
69 "Interprocedural Sparse Conditional Constant Propagation",
70 false, false)
Florian Hahn30522902018-08-23 11:04:00 +000071INITIALIZE_PASS_DEPENDENCY(DominatorTreeWrapperPass)
David Blaikie3bbf5af2018-03-22 21:41:29 +000072INITIALIZE_PASS_DEPENDENCY(TargetLibraryInfoWrapperPass)
73INITIALIZE_PASS_END(IPSCCPLegacyPass, "ipsccp",
74 "Interprocedural Sparse Conditional Constant Propagation",
75 false, false)
76
77// createIPSCCPPass - This is the public interface to this file.
78ModulePass *llvm::createIPSCCPPass() { return new IPSCCPLegacyPass(); }