Jlm
RegionAwareModRefSummarizer.hpp
Go to the documentation of this file.
1 /*
2  * Copyright 2022 Nico Reißmann <nico.reissmann@gmail.com>
3  * Copyright 2025 Håvard Krogstie <krogstie.havard@gmail.com>
4  * See COPYING for terms of redistribution.
5  */
6 
7 #ifndef JLM_LLVM_OPT_ALIAS_ANALYSES_REGIONAWAREMODREFSUMMARIZER_HPP
8 #define JLM_LLVM_OPT_ALIAS_ANALYSES_REGIONAWAREMODREFSUMMARIZER_HPP
9 
12 
13 namespace jlm::llvm::aa
14 {
15 
16 class RegionAwareModRefSummary;
17 using ModRefSetIndex = uint32_t;
18 
56 {
57 public:
58  class Statistics;
59  struct Context;
60 
61  ~RegionAwareModRefSummarizer() noexcept override;
62 
64 
66 
68  operator=(const RegionAwareModRefSummarizer &) = delete;
69 
70  std::unique_ptr<ModRefSummary>
72  const rvsdg::RvsdgModule & rvsdgModule,
73  const PointsToGraph & pointsToGraph,
74  util::StatisticsCollector & statisticsCollector) override;
75 
85  static std::unique_ptr<ModRefSummary>
86  Create(
87  const rvsdg::RvsdgModule & rvsdgModule,
88  const PointsToGraph & pointsToGraph,
89  util::StatisticsCollector & statisticsCollector);
90 
99  static std::unique_ptr<ModRefSummary>
100  Create(const rvsdg::RvsdgModule & rvsdgModule, const PointsToGraph & pointsToGraph);
101 
102 private:
109  void
110  createCallGraph(const rvsdg::RvsdgModule & rvsdgModule);
111 
116  void
118 
124  static util::HashSet<PointsToGraph::NodeIndex>
125  CreateSimpleAllocaSet(const PointsToGraph & pointsToGraph);
126 
135  util::HashSet<PointsToGraph::NodeIndex>
136  GetSimpleAllocasReachableFromRegionArguments(const rvsdg::Region & region);
137 
145  bool
146  IsRecursionPossible(const rvsdg::LambdaNode & lambda) const;
147 
157  size_t
159 
164  void
166 
171  void
173 
184  void
186  ModRefSetIndex index,
187  const util::HashSet<PointsToGraph::NodeIndex> & blocklist);
188 
193  void
194  AnnotateFunction(const rvsdg::LambdaNode & lambda);
195 
202  AnnotateRegion(const rvsdg::Region & region, const rvsdg::LambdaNode & lambda);
203 
206  const rvsdg::StructuralNode & structuralNode,
207  const rvsdg::LambdaNode & lambda);
208 
209  std::optional<ModRefSetIndex>
210  AnnotateSimpleNode(const rvsdg::SimpleNode & simpleNode, const rvsdg::LambdaNode & lambda);
211 
219  void
221  ModRefSetIndex modRefSetIndex,
222  const rvsdg::Output & origin,
223  std::optional<size_t> minTargetSize,
224  const rvsdg::LambdaNode & lambda);
225 
227  AnnotateLoad(const rvsdg::SimpleNode & loadNode, const rvsdg::LambdaNode & lambda);
228 
230  AnnotateStore(const rvsdg::SimpleNode & storeNode, const rvsdg::LambdaNode & lambda);
231 
233  AnnotateAlloca(const rvsdg::SimpleNode & allocaNode);
234 
236  AnnotateMalloc(const rvsdg::SimpleNode & mallocNode);
237 
239  AnnotateFree(const rvsdg::SimpleNode & freeNode, const rvsdg::LambdaNode & lambda);
240 
242  AnnotateMemcpy(const rvsdg::SimpleNode & memcpyNode, const rvsdg::LambdaNode & lambda);
243 
245  AnnotateCall(const rvsdg::SimpleNode & callNode, const rvsdg::LambdaNode & lambda);
246 
251  void
253 
259  bool
260  VerifyBlocklists() const;
261 
265  static std::string
267 
277  static std::string
278  ToRegionTree(const rvsdg::Graph & rvsdg, const RegionAwareModRefSummary & modRefSummary);
279 
284 
285  std::unique_ptr<Context> Context_;
286 };
287 
288 }
289 
290 #endif // JLM_LLVM_OPT_ALIAS_ANALYSES_REGIONAWAREMODREFSUMMARIZER_HPP
ModRefSetIndex AnnotateStore(const rvsdg::SimpleNode &storeNode, const rvsdg::LambdaNode &lambda)
static util::HashSet< PointsToGraph::NodeIndex > CreateSimpleAllocaSet(const PointsToGraph &pointsToGraph)
ModRefSetIndex AnnotateLoad(const rvsdg::SimpleNode &loadNode, const rvsdg::LambdaNode &lambda)
void AddPointerOriginTargets(ModRefSetIndex modRefSetIndex, const rvsdg::Output &origin, std::optional< size_t > minTargetSize, const rvsdg::LambdaNode &lambda)
ModRefSetIndex AnnotateMemcpy(const rvsdg::SimpleNode &memcpyNode, const rvsdg::LambdaNode &lambda)
static std::unique_ptr< ModRefSummary > Create(const rvsdg::RvsdgModule &rvsdgModule, const PointsToGraph &pointsToGraph, util::StatisticsCollector &statisticsCollector)
void AddModRefSetBlocklist(ModRefSetIndex index, const util::HashSet< PointsToGraph::NodeIndex > &blocklist)
~RegionAwareModRefSummarizer() noexcept override
std::optional< ModRefSetIndex > AnnotateSimpleNode(const rvsdg::SimpleNode &simpleNode, const rvsdg::LambdaNode &lambda)
std::unique_ptr< RegionAwareModRefSummary > ModRefSummary_
ModRefSetIndex AnnotateMalloc(const rvsdg::SimpleNode &mallocNode)
void AddModRefSimpleConstraint(ModRefSetIndex from, ModRefSetIndex to)
bool IsRecursionPossible(const rvsdg::LambdaNode &lambda) const
static std::string CallGraphSCCsToString(const RegionAwareModRefSummarizer &summarizer)
std::unique_ptr< ModRefSummary > SummarizeModRefs(const rvsdg::RvsdgModule &rvsdgModule, const PointsToGraph &pointsToGraph, util::StatisticsCollector &statisticsCollector) override
void createCallGraph(const rvsdg::RvsdgModule &rvsdgModule)
static std::string ToRegionTree(const rvsdg::Graph &rvsdg, const RegionAwareModRefSummary &modRefSummary)
ModRefSetIndex AnnotateRegion(const rvsdg::Region &region, const rvsdg::LambdaNode &lambda)
util::HashSet< PointsToGraph::NodeIndex > GetSimpleAllocasReachableFromRegionArguments(const rvsdg::Region &region)
void AnnotateFunction(const rvsdg::LambdaNode &lambda)
ModRefSetIndex AnnotateFree(const rvsdg::SimpleNode &freeNode, const rvsdg::LambdaNode &lambda)
ModRefSetIndex AnnotateStructuralNode(const rvsdg::StructuralNode &structuralNode, const rvsdg::LambdaNode &lambda)
ModRefSetIndex AnnotateCall(const rvsdg::SimpleNode &callNode, const rvsdg::LambdaNode &lambda)
ModRefSetIndex AnnotateAlloca(const rvsdg::SimpleNode &allocaNode)
Mod/Ref summary of region-aware mod/ref summarizer.