LLVM 23.0.0git
DependenceAnalysis.h
Go to the documentation of this file.
1//===-- llvm/Analysis/DependenceAnalysis.h -------------------- -*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// DependenceAnalysis is an LLVM pass that analyses dependences between memory
10// accesses. Currently, it is an implementation of the approach described in
11//
12// Practical Dependence Testing
13// Goff, Kennedy, Tseng
14// PLDI 1991
15//
16// There's a single entry point that analyzes the dependence between a pair
17// of memory references in a function, returning either NULL, for no dependence,
18// or a more-or-less detailed description of the dependence between them.
19//
20// This pass exists to support the DependenceGraph pass. There are two separate
21// passes because there's a useful separation of concerns. A dependence exists
22// if two conditions are met:
23//
24// 1) Two instructions reference the same memory location, and
25// 2) There is a flow of control leading from one instruction to the other.
26//
27// DependenceAnalysis attacks the first condition; DependenceGraph will attack
28// the second (it's not yet ready).
29//
30// Please note that this is work in progress and the interface is subject to
31// change.
32//
33// Plausible changes:
34// Return a set of more precise dependences instead of just one dependence
35// summarizing all.
36//
37//===----------------------------------------------------------------------===//
38
39#ifndef LLVM_ANALYSIS_DEPENDENCEANALYSIS_H
40#define LLVM_ANALYSIS_DEPENDENCEANALYSIS_H
41
45#include "llvm/IR/PassManager.h"
46#include "llvm/Pass.h"
48
49namespace llvm {
50class AAResults;
51template <typename T> class ArrayRef;
52class Loop;
53class LoopInfo;
54class SCEVConstant;
55class raw_ostream;
56
57/// Dependence - This class represents a dependence between two memory
58/// memory references in a function. It contains minimal information and
59/// is used in the very common situation where the compiler is unable to
60/// determine anything beyond the existence of a dependence; that is, it
61/// represents a confused dependence (see also FullDependence). In most
62/// cases (for output, flow, and anti dependences), the dependence implies
63/// an ordering, where the source must precede the destination; in contrast,
64/// input dependences are unordered.
65///
66/// When a dependence graph is built, each Dependence will be a member of
67/// the set of predecessor edges for its destination instruction and a set
68/// if successor edges for its source instruction. These sets are represented
69/// as singly-linked lists, with the "next" fields stored in the dependence
70/// itelf.
72protected:
73 Dependence(Dependence &&) = default;
75
76public:
77 Dependence(Instruction *Source, Instruction *Destination,
78 const SCEVUnionPredicate &A)
79 : Src(Source), Dst(Destination), Assumptions(A) {}
80 virtual ~Dependence() = default;
81
82 /// Dependence::DVEntry - Each level in the distance/direction vector
83 /// has a direction (or perhaps a union of several directions), and
84 /// perhaps a distance.
85 /// The dependency information could be across a single loop level or across
86 /// two separate levels that have the same trip count and nesting depth,
87 /// which helps to provide information for loop fusion candidation.
88 /// For example, loops b and c have the same iteration count and depth:
89 /// for (a = ...) {
90 /// for (b = 0; b < 10; b++) {
91 /// }
92 /// for (c = 0; c < 10; c++) {
93 /// }
94 /// }
95 struct DVEntry {
96 enum : unsigned char {
97 NONE = 0,
98 LT = 1,
99 EQ = 2,
100 LE = 3,
101 GT = 4,
102 NE = 5,
103 GE = 6,
104 ALL = 7
105 };
106 unsigned char Direction : 3; // Init to ALL, then refine.
107 bool Scalar : 1; // Init to true.
108 bool PeelFirst : 1; // Peeling the first iteration will break dependence.
109 bool PeelLast : 1; // Peeling the last iteration will break the dependence.
110 const SCEV *Distance = nullptr; // NULL implies no distance available.
113 };
114
115 /// getSrc - Returns the source instruction for this dependence.
116 Instruction *getSrc() const { return Src; }
117
118 /// getDst - Returns the destination instruction for this dependence.
119 Instruction *getDst() const { return Dst; }
120
121 /// isInput - Returns true if this is an input dependence.
122 bool isInput() const;
123
124 /// isOutput - Returns true if this is an output dependence.
125 bool isOutput() const;
126
127 /// isFlow - Returns true if this is a flow (aka true) dependence.
128 bool isFlow() const;
129
130 /// isAnti - Returns true if this is an anti dependence.
131 bool isAnti() const;
132
133 /// isOrdered - Returns true if dependence is Output, Flow, or Anti
134 bool isOrdered() const { return isOutput() || isFlow() || isAnti(); }
135
136 /// isUnordered - Returns true if dependence is Input
137 bool isUnordered() const { return isInput(); }
138
139 /// isLoopIndependent - Returns true if this is a loop-independent
140 /// dependence.
141 virtual bool isLoopIndependent() const { return true; }
142
143 /// isConfused - Returns true if this dependence is confused
144 /// (the compiler understands nothing and makes worst-case assumptions).
145 virtual bool isConfused() const { return true; }
146
147 /// isConsistent - Returns true if this dependence is consistent
148 /// (occurs every time the source and destination are executed).
149 virtual bool isConsistent() const { return false; }
150
151 /// getLevels - Returns the number of common loops surrounding the
152 /// source and destination of the dependence.
153 virtual unsigned getLevels() const { return 0; }
154
155 /// getSameSDLevels - Returns the number of separate SameSD loops surrounding
156 /// the source and destination of the dependence.
157 virtual unsigned getSameSDLevels() const { return 0; }
158
159 /// getDVEntry - Returns the DV entry associated with a regular or a
160 /// SameSD level
161 DVEntry getDVEntry(unsigned Level, bool IsSameSD) const;
162
163 /// getDirection - Returns the direction associated with a particular
164 /// common or SameSD level.
165 virtual unsigned getDirection(unsigned Level, bool SameSD = false) const {
166 return DVEntry::ALL;
167 }
168
169 /// getDistance - Returns the distance (or NULL) associated with a
170 /// particular common or SameSD level.
171 virtual const SCEV *getDistance(unsigned Level, bool SameSD = false) const {
172 return nullptr;
173 }
174
175 /// Check if the direction vector is negative. A negative direction
176 /// vector means Src and Dst are reversed in the actual program.
177 virtual bool isDirectionNegative() const { return false; }
178
179 /// If the direction vector is negative, normalize the direction
180 /// vector to make it non-negative. Normalization is done by reversing
181 /// Src and Dst, plus reversing the dependence directions and distances
182 /// in the vector.
183 virtual bool normalize(ScalarEvolution *SE) { return false; }
184
185 /// isPeelFirst - Returns true if peeling the first iteration from
186 /// this regular or SameSD loop level will break this dependence.
187 virtual bool isPeelFirst(unsigned Level, bool SameSD = false) const {
188 return false;
189 }
190
191 /// isPeelLast - Returns true if peeling the last iteration from
192 /// this regular or SameSD loop level will break this dependence.
193 virtual bool isPeelLast(unsigned Level, bool SameSD = false) const {
194 return false;
195 }
196
197 /// inSameSDLoops - Returns true if this level is an SameSD level, i.e.,
198 /// performed across two separate loop nests that have the Same Iteration and
199 /// Depth.
200 virtual bool inSameSDLoops(unsigned Level) const { return false; }
201
202 /// isScalar - Returns true if a particular regular or SameSD level is
203 /// scalar; that is, if no subscript in the source or destination mention
204 /// the induction variable associated with the loop at this level.
205 virtual bool isScalar(unsigned Level, bool SameSD = false) const;
206
207 /// getNextPredecessor - Returns the value of the NextPredecessor field.
208 const Dependence *getNextPredecessor() const { return NextPredecessor; }
209
210 /// getNextSuccessor - Returns the value of the NextSuccessor field.
211 const Dependence *getNextSuccessor() const { return NextSuccessor; }
212
213 /// setNextPredecessor - Sets the value of the NextPredecessor
214 /// field.
215 void setNextPredecessor(const Dependence *pred) { NextPredecessor = pred; }
216
217 /// setNextSuccessor - Sets the value of the NextSuccessor field.
218 void setNextSuccessor(const Dependence *succ) { NextSuccessor = succ; }
219
220 /// getRuntimeAssumptions - Returns the runtime assumptions under which this
221 /// Dependence relation is valid.
222 SCEVUnionPredicate getRuntimeAssumptions() const { return Assumptions; }
223
224 /// dump - For debugging purposes, dumps a dependence to OS.
225 void dump(raw_ostream &OS) const;
226
227 /// dumpImp - For debugging purposes. Dumps a dependence to OS with or
228 /// without considering the SameSD levels.
229 void dumpImp(raw_ostream &OS, bool IsSameSD = false) const;
230
231protected:
233
234private:
235 SCEVUnionPredicate Assumptions;
236 const Dependence *NextPredecessor = nullptr, *NextSuccessor = nullptr;
237 friend class DependenceInfo;
238};
239
240/// FullDependence - This class represents a dependence between two memory
241/// references in a function. It contains detailed information about the
242/// dependence (direction vectors, etc.) and is used when the compiler is
243/// able to accurately analyze the interaction of the references; that is,
244/// it is not a confused dependence (see Dependence). In most cases
245/// (for output, flow, and anti dependences), the dependence implies an
246/// ordering, where the source must precede the destination; in contrast,
247/// input dependences are unordered.
248class LLVM_ABI FullDependence final : public Dependence {
249public:
250 FullDependence(Instruction *Source, Instruction *Destination,
251 const SCEVUnionPredicate &Assumes,
252 bool PossiblyLoopIndependent, unsigned Levels);
253
254 /// isLoopIndependent - Returns true if this is a loop-independent
255 /// dependence.
256 bool isLoopIndependent() const override { return LoopIndependent; }
257
258 /// isConfused - Returns true if this dependence is confused
259 /// (the compiler understands nothing and makes worst-case
260 /// assumptions).
261 bool isConfused() const override { return false; }
262
263 /// isConsistent - Returns true if this dependence is consistent
264 /// (occurs every time the source and destination are executed).
265 bool isConsistent() const override { return Consistent; }
266
267 /// getLevels - Returns the number of common loops surrounding the
268 /// source and destination of the dependence.
269 unsigned getLevels() const override { return Levels; }
270
271 /// getSameSDLevels - Returns the number of separate SameSD loops surrounding
272 /// the source and destination of the dependence.
273 unsigned getSameSDLevels() const override { return SameSDLevels; }
274
275 /// getDVEntry - Returns the DV entry associated with a regular or a
276 /// SameSD level.
277 DVEntry getDVEntry(unsigned Level, bool IsSameSD) const {
278 if (!IsSameSD) {
279 assert(0 < Level && Level <= Levels && "Level out of range");
280 return DV[Level - 1];
281 } else {
282 assert(Levels < Level &&
283 Level <= static_cast<unsigned>(Levels) + SameSDLevels &&
284 "isSameSD level out of range");
285 return DVSameSD[Level - Levels - 1];
286 }
287 }
288
289 /// getDirection - Returns the direction associated with a particular
290 /// common or SameSD level.
291 unsigned getDirection(unsigned Level, bool SameSD = false) const override;
292
293 /// getDistance - Returns the distance (or NULL) associated with a
294 /// particular common or SameSD level.
295 const SCEV *getDistance(unsigned Level, bool SameSD = false) const override;
296
297 /// Check if the direction vector is negative. A negative direction
298 /// vector means Src and Dst are reversed in the actual program.
299 bool isDirectionNegative() const override;
300
301 /// If the direction vector is negative, normalize the direction
302 /// vector to make it non-negative. Normalization is done by reversing
303 /// Src and Dst, plus reversing the dependence directions and distances
304 /// in the vector.
305 bool normalize(ScalarEvolution *SE) override;
306
307 /// isPeelFirst - Returns true if peeling the first iteration from
308 /// this regular or SameSD loop level will break this dependence.
309 bool isPeelFirst(unsigned Level, bool SameSD = false) const override;
310
311 /// isPeelLast - Returns true if peeling the last iteration from
312 /// this regular or SameSD loop level will break this dependence.
313 bool isPeelLast(unsigned Level, bool SameSD = false) const override;
314
315 /// inSameSDLoops - Returns true if this level is an SameSD level, i.e.,
316 /// performed across two separate loop nests that have the Same Iteration and
317 /// Depth.
318 bool inSameSDLoops(unsigned Level) const override;
319
320 /// isScalar - Returns true if a particular regular or SameSD level is
321 /// scalar; that is, if no subscript in the source or destination mention
322 /// the induction variable associated with the loop at this level.
323 bool isScalar(unsigned Level, bool SameSD = false) const override;
324
325private:
326 unsigned short Levels;
327 unsigned short SameSDLevels;
328 bool LoopIndependent;
329 bool Consistent; // Init to true, then refine.
330 std::unique_ptr<DVEntry[]> DV;
331 std::unique_ptr<DVEntry[]> DVSameSD; // DV entries on SameSD levels
332 friend class DependenceInfo;
333};
334
335/// DependenceInfo - This class is the main dependence-analysis driver.
337public:
339 : AA(AA), SE(SE), LI(LI), F(F) {}
340
341 /// Handle transitive invalidation when the cached analysis results go away.
343 FunctionAnalysisManager::Invalidator &Inv);
344
345 /// depends - Tests for a dependence between the Src and Dst instructions.
346 /// Returns NULL if no dependence; otherwise, returns a Dependence (or a
347 /// FullDependence) with as much information as can be gleaned. By default,
348 /// the dependence test collects a set of runtime assumptions that cannot be
349 /// solved at compilation time. By default UnderRuntimeAssumptions is false
350 /// for a safe approximation of the dependence relation that does not
351 /// require runtime checks.
352 LLVM_ABI std::unique_ptr<Dependence>
354 bool UnderRuntimeAssumptions = false);
355
356 Function *getFunction() const { return F; }
357
358private:
359 AAResults *AA;
360 ScalarEvolution *SE;
361 LoopInfo *LI;
362 Function *F;
363
364 /// Subscript - This private struct represents a pair of subscripts from
365 /// a pair of potentially multi-dimensional array references. We use a
366 /// vector of them to guide subscript partitioning.
367 struct Subscript {
368 const SCEV *Src;
369 const SCEV *Dst;
370 enum ClassificationKind { ZIV, SIV, RDIV, MIV, NonLinear } Classification;
371 SmallBitVector Loops;
372 SmallBitVector GroupLoops;
373 SmallBitVector Group;
374 };
375
376 struct CoefficientInfo {
377 const SCEV *Coeff;
378 const SCEV *PosPart;
379 const SCEV *NegPart;
380 const SCEV *Iterations;
381 };
382
383 struct BoundInfo {
384 const SCEV *Iterations;
385 const SCEV *Upper[8];
386 const SCEV *Lower[8];
387 unsigned char Direction;
388 unsigned char DirSet;
389 };
390
391 /// Returns true if two loops have the Same iteration Space and Depth. To be
392 /// more specific, two loops have SameSD if they are in the same nesting
393 /// depth and have the same backedge count. SameSD stands for Same iteration
394 /// Space and Depth.
395 bool haveSameSD(const Loop *SrcLoop, const Loop *DstLoop) const;
396
397 /// establishNestingLevels - Examines the loop nesting of the Src and Dst
398 /// instructions and establishes their shared loops. Sets the variables
399 /// CommonLevels, SrcLevels, and MaxLevels.
400 /// The source and destination instructions needn't be contained in the same
401 /// loop. The routine establishNestingLevels finds the level of most deeply
402 /// nested loop that contains them both, CommonLevels. An instruction that's
403 /// not contained in a loop is at level = 0. MaxLevels is equal to the level
404 /// of the source plus the level of the destination, minus CommonLevels.
405 /// This lets us allocate vectors MaxLevels in length, with room for every
406 /// distinct loop referenced in both the source and destination subscripts.
407 /// The variable SrcLevels is the nesting depth of the source instruction.
408 /// It's used to help calculate distinct loops referenced by the destination.
409 /// Here's the map from loops to levels:
410 /// 0 - unused
411 /// 1 - outermost common loop
412 /// ... - other common loops
413 /// CommonLevels - innermost common loop
414 /// ... - loops containing Src but not Dst
415 /// SrcLevels - innermost loop containing Src but not Dst
416 /// ... - loops containing Dst but not Src
417 /// MaxLevels - innermost loop containing Dst but not Src
418 /// Consider the follow code fragment:
419 /// for (a = ...) {
420 /// for (b = ...) {
421 /// for (c = ...) {
422 /// for (d = ...) {
423 /// A[] = ...;
424 /// }
425 /// }
426 /// for (e = ...) {
427 /// for (f = ...) {
428 /// for (g = ...) {
429 /// ... = A[];
430 /// }
431 /// }
432 /// }
433 /// }
434 /// }
435 /// If we're looking at the possibility of a dependence between the store
436 /// to A (the Src) and the load from A (the Dst), we'll note that they
437 /// have 2 loops in common, so CommonLevels will equal 2 and the direction
438 /// vector for Result will have 2 entries. SrcLevels = 4 and MaxLevels = 7.
439 /// A map from loop names to level indices would look like
440 /// a - 1
441 /// b - 2 = CommonLevels
442 /// c - 3
443 /// d - 4 = SrcLevels
444 /// e - 5
445 /// f - 6
446 /// g - 7 = MaxLevels
447 /// SameSDLevels counts the number of levels after common levels that are
448 /// not common but have the same iteration space and depth. Internally this
449 /// is checked using haveSameSD. Assume that in this code fragment, levels c
450 /// and e have the same iteration space and depth, but levels d and f does
451 /// not. Then SameSDLevels is set to 1. In that case the level numbers for the
452 /// previous code look like
453 /// a - 1
454 /// b - 2
455 /// c,e - 3 = CommonLevels
456 /// d - 4 = SrcLevels
457 /// f - 5
458 /// g - 6 = MaxLevels
459 void establishNestingLevels(const Instruction *Src, const Instruction *Dst);
460
461 unsigned CommonLevels, SrcLevels, MaxLevels, SameSDLevels;
462
463 /// mapSrcLoop - Given one of the loops containing the source, return
464 /// its level index in our numbering scheme.
465 unsigned mapSrcLoop(const Loop *SrcLoop) const;
466
467 /// mapDstLoop - Given one of the loops containing the destination,
468 /// return its level index in our numbering scheme.
469 unsigned mapDstLoop(const Loop *DstLoop) const;
470
471 /// isLoopInvariant - Returns true if Expression is loop invariant
472 /// in LoopNest.
473 bool isLoopInvariant(const SCEV *Expression, const Loop *LoopNest) const;
474
475 /// collectCommonLoops - Finds the set of loops from the LoopNest that
476 /// have a level <= CommonLevels and are referred to by the SCEV Expression.
477 void collectCommonLoops(const SCEV *Expression, const Loop *LoopNest,
478 SmallBitVector &Loops) const;
479
480 /// checkSrcSubscript - Examines the SCEV Src, returning true iff it's
481 /// linear. Collect the set of loops mentioned by Src.
482 bool checkSrcSubscript(const SCEV *Src, const Loop *LoopNest,
483 SmallBitVector &Loops);
484
485 /// checkDstSubscript - Examines the SCEV Dst, returning true iff it's
486 /// linear. Collect the set of loops mentioned by Dst.
487 bool checkDstSubscript(const SCEV *Dst, const Loop *LoopNest,
488 SmallBitVector &Loops);
489
490 /// collectUpperBound - All subscripts are the same type (on my machine,
491 /// an i64). The loop bound may be a smaller type. collectUpperBound
492 /// find the bound, if available, and zero extends it to the Type T.
493 /// (I zero extend since the bound should always be >= 0.)
494 /// If no upper bound is available, return NULL.
495 const SCEV *collectUpperBound(const Loop *l, Type *T) const;
496
497 /// collectConstantUpperBound - Calls collectUpperBound(), then
498 /// attempts to cast it to SCEVConstant. If the cast fails,
499 /// returns NULL.
500 const SCEVConstant *collectConstantUpperBound(const Loop *l, Type *T) const;
501
502 /// classifyPair - Examines the subscript pair (the Src and Dst SCEVs)
503 /// and classifies it as either ZIV, SIV, RDIV, MIV, or Nonlinear.
504 /// Collects the associated loops in a set.
505 Subscript::ClassificationKind
506 classifyPair(const SCEV *Src, const Loop *SrcLoopNest, const SCEV *Dst,
507 const Loop *DstLoopNest, SmallBitVector &Loops);
508
509 /// testZIV - Tests the ZIV subscript pair (Src and Dst) for dependence.
510 /// Returns true if any possible dependence is disproved.
511 /// If there might be a dependence, returns false.
512 /// If the dependence isn't proven to exist,
513 /// marks the Result as inconsistent.
514 bool testZIV(const SCEV *Src, const SCEV *Dst, FullDependence &Result) const;
515
516 /// testSIV - Tests the SIV subscript pair (Src and Dst) for dependence.
517 /// Things of the form [c1 + a1*i] and [c2 + a2*j], where
518 /// i and j are induction variables, c1 and c2 are loop invariant,
519 /// and a1 and a2 are constant.
520 /// Returns true if any possible dependence is disproved.
521 /// If there might be a dependence, returns false.
522 /// Sets appropriate direction vector entry and, when possible,
523 /// the distance vector entry.
524 /// If the dependence isn't proven to exist,
525 /// marks the Result as inconsistent.
526 bool testSIV(const SCEV *Src, const SCEV *Dst, unsigned &Level,
527 FullDependence &Result, bool UnderRuntimeAssumptions);
528
529 /// testRDIV - Tests the RDIV subscript pair (Src and Dst) for dependence.
530 /// Things of the form [c1 + a1*i] and [c2 + a2*j]
531 /// where i and j are induction variables, c1 and c2 are loop invariant,
532 /// and a1 and a2 are constant.
533 /// With minor algebra, this test can also be used for things like
534 /// [c1 + a1*i + a2*j][c2].
535 /// Returns true if any possible dependence is disproved.
536 /// If there might be a dependence, returns false.
537 /// Marks the Result as inconsistent.
538 bool testRDIV(const SCEV *Src, const SCEV *Dst, FullDependence &Result) const;
539
540 /// testMIV - Tests the MIV subscript pair (Src and Dst) for dependence.
541 /// Returns true if dependence disproved.
542 /// Can sometimes refine direction vectors.
543 bool testMIV(const SCEV *Src, const SCEV *Dst, const SmallBitVector &Loops,
544 FullDependence &Result) const;
545
546 /// strongSIVtest - Tests the strong SIV subscript pair (\p Src and \p Dst)
547 /// for dependence.
548 /// Things of the form [c1 + a*i] and [c2 + a*i],
549 /// where i is an induction variable, c1 and c2 are loop invariant,
550 /// and a is a constant
551 /// Returns true if any possible dependence is disproved.
552 /// If there might be a dependence, returns false.
553 /// Sets appropriate direction and distance.
554 bool strongSIVtest(const SCEVAddRecExpr *Src, const SCEVAddRecExpr *Dst,
555 unsigned Level, FullDependence &Result,
556 bool UnderRuntimeAssumptions);
557
558 /// weakCrossingSIVtest - Tests the weak-crossing SIV subscript pair
559 /// (Src and Dst) for dependence.
560 /// Things of the form [c1 + a*i] and [c2 - a*i],
561 /// where i is an induction variable, c1 and c2 are loop invariant,
562 /// and a is a constant.
563 /// Returns true if any possible dependence is disproved.
564 /// If there might be a dependence, returns false.
565 /// Sets appropriate direction entry.
566 /// Set consistent to false.
567 bool weakCrossingSIVtest(const SCEV *SrcCoeff, const SCEV *SrcConst,
568 const SCEV *DstConst, const Loop *CurrentSrcLoop,
569 const Loop *CurrentDstLoop, unsigned Level,
570 FullDependence &Result) const;
571
572 /// ExactSIVtest - Tests the SIV subscript pair
573 /// (Src and Dst) for dependence.
574 /// Things of the form [c1 + a1*i] and [c2 + a2*i],
575 /// where i is an induction variable, c1 and c2 are loop invariant,
576 /// and a1 and a2 are constant.
577 /// Returns true if any possible dependence is disproved.
578 /// If there might be a dependence, returns false.
579 /// Sets appropriate direction entry.
580 /// Set consistent to false.
581 bool exactSIVtest(const SCEV *SrcCoeff, const SCEV *DstCoeff,
582 const SCEV *SrcConst, const SCEV *DstConst,
583 const Loop *CurrentSrcLoop, const Loop *CurrentDstLoop,
584 unsigned Level, FullDependence &Result) const;
585
586 /// weakZeroSrcSIVtest - Tests the weak-zero SIV subscript pair
587 /// (Src and Dst) for dependence.
588 /// Things of the form [c1] and [c2 + a*i],
589 /// where i is an induction variable, c1 and c2 are loop invariant,
590 /// and a is a constant. See also weakZeroDstSIVtest.
591 /// Returns true if any possible dependence is disproved.
592 /// If there might be a dependence, returns false.
593 /// Sets appropriate direction entry.
594 /// Set consistent to false.
595 /// If loop peeling will break the dependence, mark appropriately.
596 bool weakZeroSrcSIVtest(const SCEV *DstCoeff, const SCEV *SrcConst,
597 const SCEV *DstConst, const Loop *CurrentSrcLoop,
598 const Loop *CurrentDstLoop, unsigned Level,
599 FullDependence &Result) const;
600
601 /// weakZeroDstSIVtest - Tests the weak-zero SIV subscript pair
602 /// (Src and Dst) for dependence.
603 /// Things of the form [c1 + a*i] and [c2],
604 /// where i is an induction variable, c1 and c2 are loop invariant,
605 /// and a is a constant. See also weakZeroSrcSIVtest.
606 /// Returns true if any possible dependence is disproved.
607 /// If there might be a dependence, returns false.
608 /// Sets appropriate direction entry.
609 /// Set consistent to false.
610 /// If loop peeling will break the dependence, mark appropriately.
611 bool weakZeroDstSIVtest(const SCEV *SrcCoeff, const SCEV *SrcConst,
612 const SCEV *DstConst, const Loop *CurrentSrcLoop,
613 const Loop *CurrentDstLoop, unsigned Level,
614 FullDependence &Result) const;
615
616 /// exactRDIVtest - Tests the RDIV subscript pair for dependence.
617 /// Things of the form [c1 + a*i] and [c2 + b*j],
618 /// where i and j are induction variable, c1 and c2 are loop invariant,
619 /// and a and b are constants.
620 /// Returns true if any possible dependence is disproved.
621 /// Marks the result as inconsistent.
622 /// Works in some cases that symbolicRDIVtest doesn't,
623 /// and vice versa.
624 bool exactRDIVtest(const SCEV *SrcCoeff, const SCEV *DstCoeff,
625 const SCEV *SrcConst, const SCEV *DstConst,
626 const Loop *SrcLoop, const Loop *DstLoop,
627 FullDependence &Result) const;
628
629 /// symbolicRDIVtest - Tests the RDIV subscript pair for dependence.
630 /// Things of the form [c1 + a*i] and [c2 + b*j],
631 /// where i and j are induction variable, c1 and c2 are loop invariant,
632 /// and a and b are constants.
633 /// Returns true if any possible dependence is disproved.
634 /// Marks the result as inconsistent.
635 /// Works in some cases that exactRDIVtest doesn't,
636 /// and vice versa. Can also be used as a backup for
637 /// ordinary SIV tests.
638 bool symbolicRDIVtest(const SCEV *SrcCoeff, const SCEV *DstCoeff,
639 const SCEV *SrcConst, const SCEV *DstConst,
640 const Loop *SrcLoop, const Loop *DstLoop) const;
641
642 /// gcdMIVtest - Tests an MIV subscript pair for dependence.
643 /// Returns true if any possible dependence is disproved.
644 /// Marks the result as inconsistent.
645 /// Can sometimes disprove the equal direction for 1 or more loops.
646 // Can handle some symbolics that even the SIV tests don't get,
647 /// so we use it as a backup for everything.
648 bool gcdMIVtest(const SCEV *Src, const SCEV *Dst,
649 FullDependence &Result) const;
650
651 /// banerjeeMIVtest - Tests an MIV subscript pair for dependence.
652 /// Returns true if any possible dependence is disproved.
653 /// Marks the result as inconsistent.
654 /// Computes directions.
655 bool banerjeeMIVtest(const SCEV *Src, const SCEV *Dst,
656 const SmallBitVector &Loops,
657 FullDependence &Result) const;
658
659 /// collectCoeffInfo - Walks through the subscript, collecting each
660 /// coefficient, the associated loop bounds, and recording its positive and
661 /// negative parts for later use.
662 CoefficientInfo *collectCoeffInfo(const SCEV *Subscript, bool SrcFlag,
663 const SCEV *&Constant) const;
664
665 /// Given \p Expr of the form
666 ///
667 /// c_0*X_0*i_0 + c_1*X_1*i_1 + ...c_n*X_n*i_n + C
668 ///
669 /// compute
670 ///
671 /// RunningGCD = gcd(RunningGCD, c_0, c_1, ..., c_n)
672 ///
673 /// where c_0, c_1, ..., and c_n are the constant values. The result is stored
674 /// in \p RunningGCD. Also, the initial value of \p RunningGCD affects the
675 /// result. If we find a term like (c_k * X_k * i_k), where i_k is the
676 /// induction variable of \p CurLoop, c_k is stored in \p CurLoopCoeff and not
677 /// included in the GCD computation. Returns false if we fail to find a
678 /// constant coefficient for some loop, e.g., when a term like (X+Y)*i is
679 /// present. Otherwise returns true.
680 bool accumulateCoefficientsGCD(const SCEV *Expr, const Loop *CurLoop,
681 const SCEV *&CurLoopCoeff,
682 APInt &RunningGCD) const;
683
684 /// getPositivePart - X^+ = max(X, 0).
685 const SCEV *getPositivePart(const SCEV *X) const;
686
687 /// getNegativePart - X^- = min(X, 0).
688 const SCEV *getNegativePart(const SCEV *X) const;
689
690 /// getLowerBound - Looks through all the bounds info and
691 /// computes the lower bound given the current direction settings
692 /// at each level.
693 const SCEV *getLowerBound(BoundInfo *Bound) const;
694
695 /// getUpperBound - Looks through all the bounds info and
696 /// computes the upper bound given the current direction settings
697 /// at each level.
698 const SCEV *getUpperBound(BoundInfo *Bound) const;
699
700 /// exploreDirections - Hierarchically expands the direction vector
701 /// search space, combining the directions of discovered dependences
702 /// in the DirSet field of Bound. Returns the number of distinct
703 /// dependences discovered. If the dependence is disproved,
704 /// it will return 0.
705 unsigned exploreDirections(unsigned Level, CoefficientInfo *A,
706 CoefficientInfo *B, BoundInfo *Bound,
707 const SmallBitVector &Loops,
708 unsigned &DepthExpanded, const SCEV *Delta) const;
709
710 /// testBounds - Returns true iff the current bounds are plausible.
711 bool testBounds(unsigned char DirKind, unsigned Level, BoundInfo *Bound,
712 const SCEV *Delta) const;
713
714 /// findBoundsALL - Computes the upper and lower bounds for level K
715 /// using the * direction. Records them in Bound.
716 void findBoundsALL(CoefficientInfo *A, CoefficientInfo *B, BoundInfo *Bound,
717 unsigned K) const;
718
719 /// findBoundsLT - Computes the upper and lower bounds for level K
720 /// using the < direction. Records them in Bound.
721 void findBoundsLT(CoefficientInfo *A, CoefficientInfo *B, BoundInfo *Bound,
722 unsigned K) const;
723
724 /// findBoundsGT - Computes the upper and lower bounds for level K
725 /// using the > direction. Records them in Bound.
726 void findBoundsGT(CoefficientInfo *A, CoefficientInfo *B, BoundInfo *Bound,
727 unsigned K) const;
728
729 /// findBoundsEQ - Computes the upper and lower bounds for level K
730 /// using the = direction. Records them in Bound.
731 void findBoundsEQ(CoefficientInfo *A, CoefficientInfo *B, BoundInfo *Bound,
732 unsigned K) const;
733
734 /// Given a linear access function, tries to recover subscripts
735 /// for each dimension of the array element access.
736 bool tryDelinearize(Instruction *Src, Instruction *Dst,
737 SmallVectorImpl<Subscript> &Pair);
738
739 /// Tries to delinearize \p Src and \p Dst access functions for a fixed size
740 /// multi-dimensional array. Calls delinearizeFixedSizeArray() to delinearize
741 /// \p Src and \p Dst separately,
742 bool tryDelinearizeFixedSize(Instruction *Src, Instruction *Dst,
743 const SCEV *SrcAccessFn, const SCEV *DstAccessFn,
744 SmallVectorImpl<const SCEV *> &SrcSubscripts,
745 SmallVectorImpl<const SCEV *> &DstSubscripts);
746
747 /// Tries to delinearize access function for a multi-dimensional array with
748 /// symbolic runtime sizes.
749 /// Returns true upon success and false otherwise.
750 bool
751 tryDelinearizeParametricSize(Instruction *Src, Instruction *Dst,
752 const SCEV *SrcAccessFn, const SCEV *DstAccessFn,
753 SmallVectorImpl<const SCEV *> &SrcSubscripts,
754 SmallVectorImpl<const SCEV *> &DstSubscripts);
755
756 /// checkSubscript - Helper function for checkSrcSubscript and
757 /// checkDstSubscript to avoid duplicate code
758 bool checkSubscript(const SCEV *Expr, const Loop *LoopNest,
759 SmallBitVector &Loops, bool IsSrc);
760}; // class DependenceInfo
761
762/// AnalysisPass to compute dependence information in a function
763class DependenceAnalysis : public AnalysisInfoMixin<DependenceAnalysis> {
764public:
767
768private:
771}; // class DependenceAnalysis
772
773/// Printer pass to dump DA results.
775 : public PassInfoMixin<DependenceAnalysisPrinterPass> {
776 DependenceAnalysisPrinterPass(raw_ostream &OS, bool NormalizeResults = false)
777 : OS(OS), NormalizeResults(NormalizeResults) {}
778
780
781 static bool isRequired() { return true; }
782
783private:
784 raw_ostream &OS;
785 bool NormalizeResults;
786}; // class DependenceAnalysisPrinterPass
787
788/// Legacy pass manager pass to access dependence information
790public:
791 static char ID; // Class identification, replacement for typeinfo
793
794 bool runOnFunction(Function &F) override;
795 void releaseMemory() override;
796 void getAnalysisUsage(AnalysisUsage &) const override;
797 void print(raw_ostream &, const Module * = nullptr) const override;
798 DependenceInfo &getDI() const;
799
800private:
801 std::unique_ptr<DependenceInfo> info;
802}; // class DependenceAnalysisWrapperPass
803
804/// createDependenceAnalysisPass - This creates an instance of the
805/// DependenceAnalysis wrapper pass.
807
808} // namespace llvm
809
810#endif
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_ABI
Definition Compiler.h:213
static bool runOnFunction(Function &F, bool PostInlining)
Hexagon Hardware Loops
This header defines various interfaces for pass management in LLVM.
#define F(x, y, z)
Definition MD5.cpp:54
#define T
static bool isInput(const ArrayRef< StringRef > &Prefixes, StringRef Arg)
Definition OptTable.cpp:148
FunctionAnalysisManager FAM
This file implements the SmallBitVector class.
static TableGen::Emitter::OptClass< SkeletonEmitter > X("gen-skeleton-class", "Generate example skeleton class")
Represent the analysis usage information of a pass.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
void getAnalysisUsage(AnalysisUsage &) const override
getAnalysisUsage - This function should be overriden by passes that need analysis information to do t...
void releaseMemory() override
releaseMemory() - This member can be implemented by a pass if it wants to be able to release its memo...
AnalysisPass to compute dependence information in a function.
LLVM_ABI Result run(Function &F, FunctionAnalysisManager &FAM)
DependenceInfo - This class is the main dependence-analysis driver.
LLVM_ABI bool invalidate(Function &F, const PreservedAnalyses &PA, FunctionAnalysisManager::Invalidator &Inv)
Handle transitive invalidation when the cached analysis results go away.
Function * getFunction() const
DependenceInfo(Function *F, AAResults *AA, ScalarEvolution *SE, LoopInfo *LI)
LLVM_ABI std::unique_ptr< Dependence > depends(Instruction *Src, Instruction *Dst, bool UnderRuntimeAssumptions=false)
depends - Tests for a dependence between the Src and Dst instructions.
Instruction * getDst() const
getDst - Returns the destination instruction for this dependence.
Dependence & operator=(Dependence &&)=default
bool isOrdered() const
isOrdered - Returns true if dependence is Output, Flow, or Anti
void setNextSuccessor(const Dependence *succ)
setNextSuccessor - Sets the value of the NextSuccessor field.
friend class DependenceInfo
Dependence(Instruction *Source, Instruction *Destination, const SCEVUnionPredicate &A)
Dependence(Dependence &&)=default
bool isUnordered() const
isUnordered - Returns true if dependence is Input
SCEVUnionPredicate getRuntimeAssumptions() const
getRuntimeAssumptions - Returns the runtime assumptions under which this Dependence relation is valid...
DVEntry getDVEntry(unsigned Level, bool IsSameSD) const
getDVEntry - Returns the DV entry associated with a regular or a SameSD level
virtual bool isConfused() const
isConfused - Returns true if this dependence is confused (the compiler understands nothing and makes ...
virtual unsigned getSameSDLevels() const
getSameSDLevels - Returns the number of separate SameSD loops surrounding the source and destination ...
virtual const SCEV * getDistance(unsigned Level, bool SameSD=false) const
getDistance - Returns the distance (or NULL) associated with a particular common or SameSD level.
virtual bool isPeelLast(unsigned Level, bool SameSD=false) const
isPeelLast - Returns true if peeling the last iteration from this regular or SameSD loop level will b...
virtual bool isConsistent() const
isConsistent - Returns true if this dependence is consistent (occurs every time the source and destin...
virtual unsigned getLevels() const
getLevels - Returns the number of common loops surrounding the source and destination of the dependen...
const Dependence * getNextPredecessor() const
getNextPredecessor - Returns the value of the NextPredecessor field.
virtual unsigned getDirection(unsigned Level, bool SameSD=false) const
getDirection - Returns the direction associated with a particular common or SameSD level.
bool isFlow() const
isFlow - Returns true if this is a flow (aka true) dependence.
virtual bool isPeelFirst(unsigned Level, bool SameSD=false) const
isPeelFirst - Returns true if peeling the first iteration from this regular or SameSD loop level will...
virtual ~Dependence()=default
virtual bool normalize(ScalarEvolution *SE)
If the direction vector is negative, normalize the direction vector to make it non-negative.
bool isAnti() const
isAnti - Returns true if this is an anti dependence.
const Dependence * getNextSuccessor() const
getNextSuccessor - Returns the value of the NextSuccessor field.
virtual bool isDirectionNegative() const
Check if the direction vector is negative.
Instruction * getSrc() const
getSrc - Returns the source instruction for this dependence.
virtual bool isLoopIndependent() const
isLoopIndependent - Returns true if this is a loop-independent dependence.
bool isOutput() const
isOutput - Returns true if this is an output dependence.
void setNextPredecessor(const Dependence *pred)
setNextPredecessor - Sets the value of the NextPredecessor field.
virtual bool inSameSDLoops(unsigned Level) const
inSameSDLoops - Returns true if this level is an SameSD level, i.e., performed across two separate lo...
FullDependence(Instruction *Source, Instruction *Destination, const SCEVUnionPredicate &Assumes, bool PossiblyLoopIndependent, unsigned Levels)
bool isConfused() const override
isConfused - Returns true if this dependence is confused (the compiler understands nothing and makes ...
DVEntry getDVEntry(unsigned Level, bool IsSameSD) const
getDVEntry - Returns the DV entry associated with a regular or a SameSD level.
bool isLoopIndependent() const override
isLoopIndependent - Returns true if this is a loop-independent dependence.
unsigned getSameSDLevels() const override
getSameSDLevels - Returns the number of separate SameSD loops surrounding the source and destination ...
unsigned getLevels() const override
getLevels - Returns the number of common loops surrounding the source and destination of the dependen...
bool isConsistent() const override
isConsistent - Returns true if this dependence is consistent (occurs every time the source and destin...
FunctionPass class - This class is used to implement most global optimizations.
Definition Pass.h:314
FunctionPass(char &pid)
Definition Pass.h:316
Represents a single loop in the control flow graph.
Definition LoopInfo.h:40
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
A set of analyses that are preserved following a run of a transformation pass.
Definition Analysis.h:112
This class represents a constant integer value.
This class represents a composition of other SCEV predicates, and is the class that most clients will...
This class represents an analyzed expression in the program.
The main scalar evolution driver.
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition raw_ostream.h:53
Abstract Attribute helper functions.
Definition Attributor.h:165
This is an optimization pass for GlobalISel generic memory operations.
Definition Types.h:26
void dump(const SparseBitVector< ElementSize > &LHS, raw_ostream &out)
AnalysisManager< Function > FunctionAnalysisManager
Convenience typedef for the Function analysis manager.
LLVM_ABI FunctionPass * createDependenceAnalysisWrapperPass()
createDependenceAnalysisPass - This creates an instance of the DependenceAnalysis wrapper pass.
A CRTP mix-in that provides informational APIs needed for analysis passes.
Definition PassManager.h:93
A special type used by analysis passes to provide an address that identifies that particular analysis...
Definition Analysis.h:29
DependenceAnalysisPrinterPass(raw_ostream &OS, bool NormalizeResults=false)
LLVM_ABI PreservedAnalyses run(Function &F, FunctionAnalysisManager &FAM)
Dependence::DVEntry - Each level in the distance/direction vector has a direction (or perhaps a union...
A CRTP mix-in to automatically provide informational APIs needed for passes.
Definition PassManager.h:70