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 /// Makes sure all subscript pairs share the same integer type by
476 /// sign-extending as necessary.
477 /// Sign-extending a subscript is safe because getelementptr assumes the
478 /// array subscripts are signed.
479 void unifySubscriptType(ArrayRef<Subscript *> Pairs);
480
481 /// removeMatchingExtensions - Examines a subscript pair.
482 /// If the source and destination are identically sign (or zero)
483 /// extended, it strips off the extension in an effort to
484 /// simplify the actual analysis.
485 void removeMatchingExtensions(Subscript *Pair);
486
487 /// collectCommonLoops - Finds the set of loops from the LoopNest that
488 /// have a level <= CommonLevels and are referred to by the SCEV Expression.
489 void collectCommonLoops(const SCEV *Expression, const Loop *LoopNest,
490 SmallBitVector &Loops) const;
491
492 /// checkSrcSubscript - Examines the SCEV Src, returning true iff it's
493 /// linear. Collect the set of loops mentioned by Src.
494 bool checkSrcSubscript(const SCEV *Src, const Loop *LoopNest,
495 SmallBitVector &Loops);
496
497 /// checkDstSubscript - Examines the SCEV Dst, returning true iff it's
498 /// linear. Collect the set of loops mentioned by Dst.
499 bool checkDstSubscript(const SCEV *Dst, const Loop *LoopNest,
500 SmallBitVector &Loops);
501
502 /// collectUpperBound - All subscripts are the same type (on my machine,
503 /// an i64). The loop bound may be a smaller type. collectUpperBound
504 /// find the bound, if available, and zero extends it to the Type T.
505 /// (I zero extend since the bound should always be >= 0.)
506 /// If no upper bound is available, return NULL.
507 const SCEV *collectUpperBound(const Loop *l, Type *T) const;
508
509 /// collectConstantUpperBound - Calls collectUpperBound(), then
510 /// attempts to cast it to SCEVConstant. If the cast fails,
511 /// returns NULL.
512 const SCEVConstant *collectConstantUpperBound(const Loop *l, Type *T) const;
513
514 /// classifyPair - Examines the subscript pair (the Src and Dst SCEVs)
515 /// and classifies it as either ZIV, SIV, RDIV, MIV, or Nonlinear.
516 /// Collects the associated loops in a set.
517 Subscript::ClassificationKind
518 classifyPair(const SCEV *Src, const Loop *SrcLoopNest, const SCEV *Dst,
519 const Loop *DstLoopNest, SmallBitVector &Loops);
520
521 /// testZIV - Tests the ZIV subscript pair (Src and Dst) for dependence.
522 /// Returns true if any possible dependence is disproved.
523 /// If there might be a dependence, returns false.
524 /// If the dependence isn't proven to exist,
525 /// marks the Result as inconsistent.
526 bool testZIV(const SCEV *Src, const SCEV *Dst, FullDependence &Result) const;
527
528 /// testSIV - Tests the SIV subscript pair (Src and Dst) for dependence.
529 /// Things of the form [c1 + a1*i] and [c2 + a2*j], where
530 /// i and j are induction variables, c1 and c2 are loop invariant,
531 /// and a1 and a2 are constant.
532 /// Returns true if any possible dependence is disproved.
533 /// If there might be a dependence, returns false.
534 /// Sets appropriate direction vector entry and, when possible,
535 /// the distance vector entry.
536 /// If the dependence isn't proven to exist,
537 /// marks the Result as inconsistent.
538 bool testSIV(const SCEV *Src, const SCEV *Dst, unsigned &Level,
539 FullDependence &Result, bool UnderRuntimeAssumptions);
540
541 /// testRDIV - Tests the RDIV subscript pair (Src and Dst) for dependence.
542 /// Things of the form [c1 + a1*i] and [c2 + a2*j]
543 /// where i and j are induction variables, c1 and c2 are loop invariant,
544 /// and a1 and a2 are constant.
545 /// With minor algebra, this test can also be used for things like
546 /// [c1 + a1*i + a2*j][c2].
547 /// Returns true if any possible dependence is disproved.
548 /// If there might be a dependence, returns false.
549 /// Marks the Result as inconsistent.
550 bool testRDIV(const SCEV *Src, const SCEV *Dst, FullDependence &Result) const;
551
552 /// testMIV - Tests the MIV subscript pair (Src and Dst) for dependence.
553 /// Returns true if dependence disproved.
554 /// Can sometimes refine direction vectors.
555 bool testMIV(const SCEV *Src, const SCEV *Dst, const SmallBitVector &Loops,
556 FullDependence &Result) const;
557
558 /// strongSIVtest - Tests the strong SIV subscript pair (Src and Dst)
559 /// 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 and distance.
566 bool strongSIVtest(const SCEV *Coeff, const SCEV *SrcConst,
567 const SCEV *DstConst, const Loop *CurrentSrcLoop,
568 const Loop *CurrentDstLoop, unsigned Level,
569 FullDependence &Result, bool UnderRuntimeAssumptions);
570
571 /// weakCrossingSIVtest - Tests the weak-crossing SIV subscript pair
572 /// (Src and Dst) for dependence.
573 /// Things of the form [c1 + a*i] and [c2 - a*i],
574 /// where i is an induction variable, c1 and c2 are loop invariant,
575 /// and a is a constant.
576 /// Returns true if any possible dependence is disproved.
577 /// If there might be a dependence, returns false.
578 /// Sets appropriate direction entry.
579 /// Set consistent to false.
580 bool weakCrossingSIVtest(const SCEV *SrcCoeff, const SCEV *SrcConst,
581 const SCEV *DstConst, const Loop *CurrentSrcLoop,
582 const Loop *CurrentDstLoop, unsigned Level,
583 FullDependence &Result) const;
584
585 /// ExactSIVtest - Tests the SIV subscript pair
586 /// (Src and Dst) for dependence.
587 /// Things of the form [c1 + a1*i] and [c2 + a2*i],
588 /// where i is an induction variable, c1 and c2 are loop invariant,
589 /// and a1 and a2 are constant.
590 /// Returns true if any possible dependence is disproved.
591 /// If there might be a dependence, returns false.
592 /// Sets appropriate direction entry.
593 /// Set consistent to false.
594 bool exactSIVtest(const SCEV *SrcCoeff, const SCEV *DstCoeff,
595 const SCEV *SrcConst, const SCEV *DstConst,
596 const Loop *CurrentSrcLoop, const Loop *CurrentDstLoop,
597 unsigned Level, FullDependence &Result) const;
598
599 /// weakZeroSrcSIVtest - Tests the weak-zero SIV subscript pair
600 /// (Src and Dst) for dependence.
601 /// Things of the form [c1] and [c2 + a*i],
602 /// where i is an induction variable, c1 and c2 are loop invariant,
603 /// and a is a constant. See also weakZeroDstSIVtest.
604 /// Returns true if any possible dependence is disproved.
605 /// If there might be a dependence, returns false.
606 /// Sets appropriate direction entry.
607 /// Set consistent to false.
608 /// If loop peeling will break the dependence, mark appropriately.
609 bool weakZeroSrcSIVtest(const SCEV *DstCoeff, const SCEV *SrcConst,
610 const SCEV *DstConst, const Loop *CurrentSrcLoop,
611 const Loop *CurrentDstLoop, unsigned Level,
612 FullDependence &Result) const;
613
614 /// weakZeroDstSIVtest - Tests the weak-zero SIV subscript pair
615 /// (Src and Dst) for dependence.
616 /// Things of the form [c1 + a*i] and [c2],
617 /// where i is an induction variable, c1 and c2 are loop invariant,
618 /// and a is a constant. See also weakZeroSrcSIVtest.
619 /// Returns true if any possible dependence is disproved.
620 /// If there might be a dependence, returns false.
621 /// Sets appropriate direction entry.
622 /// Set consistent to false.
623 /// If loop peeling will break the dependence, mark appropriately.
624 bool weakZeroDstSIVtest(const SCEV *SrcCoeff, const SCEV *SrcConst,
625 const SCEV *DstConst, const Loop *CurrentSrcLoop,
626 const Loop *CurrentDstLoop, unsigned Level,
627 FullDependence &Result) const;
628
629 /// exactRDIVtest - 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 symbolicRDIVtest doesn't,
636 /// and vice versa.
637 bool exactRDIVtest(const SCEV *SrcCoeff, const SCEV *DstCoeff,
638 const SCEV *SrcConst, const SCEV *DstConst,
639 const Loop *SrcLoop, const Loop *DstLoop,
640 FullDependence &Result) const;
641
642 /// symbolicRDIVtest - Tests the RDIV subscript pair for dependence.
643 /// Things of the form [c1 + a*i] and [c2 + b*j],
644 /// where i and j are induction variable, c1 and c2 are loop invariant,
645 /// and a and b are constants.
646 /// Returns true if any possible dependence is disproved.
647 /// Marks the result as inconsistent.
648 /// Works in some cases that exactRDIVtest doesn't,
649 /// and vice versa. Can also be used as a backup for
650 /// ordinary SIV tests.
651 bool symbolicRDIVtest(const SCEV *SrcCoeff, const SCEV *DstCoeff,
652 const SCEV *SrcConst, const SCEV *DstConst,
653 const Loop *SrcLoop, const Loop *DstLoop) const;
654
655 /// gcdMIVtest - Tests an MIV subscript pair for dependence.
656 /// Returns true if any possible dependence is disproved.
657 /// Marks the result as inconsistent.
658 /// Can sometimes disprove the equal direction for 1 or more loops.
659 // Can handle some symbolics that even the SIV tests don't get,
660 /// so we use it as a backup for everything.
661 bool gcdMIVtest(const SCEV *Src, const SCEV *Dst,
662 FullDependence &Result) const;
663
664 /// banerjeeMIVtest - Tests an MIV subscript pair for dependence.
665 /// Returns true if any possible dependence is disproved.
666 /// Marks the result as inconsistent.
667 /// Computes directions.
668 bool banerjeeMIVtest(const SCEV *Src, const SCEV *Dst,
669 const SmallBitVector &Loops,
670 FullDependence &Result) const;
671
672 /// collectCoeffInfo - Walks through the subscript, collecting each
673 /// coefficient, the associated loop bounds, and recording its positive and
674 /// negative parts for later use.
675 CoefficientInfo *collectCoeffInfo(const SCEV *Subscript, bool SrcFlag,
676 const SCEV *&Constant) const;
677
678 /// Given \p Expr of the form
679 ///
680 /// c_0*X_0*i_0 + c_1*X_1*i_1 + ...c_n*X_n*i_n + C
681 ///
682 /// compute
683 ///
684 /// RunningGCD = gcd(RunningGCD, c_0, c_1, ..., c_n)
685 ///
686 /// where c_0, c_1, ..., and c_n are the constant values. The result is stored
687 /// in \p RunningGCD. Also, the initial value of \p RunningGCD affects the
688 /// result. If we find a term like (c_k * X_k * i_k), where i_k is the
689 /// induction variable of \p CurLoop, c_k is stored in \p CurLoopCoeff and not
690 /// included in the GCD computation. Returns false if we fail to find a
691 /// constant coefficient for some loop, e.g., when a term like (X+Y)*i is
692 /// present. Otherwise returns true.
693 bool accumulateCoefficientsGCD(const SCEV *Expr, const Loop *CurLoop,
694 const SCEV *&CurLoopCoeff,
695 APInt &RunningGCD) const;
696
697 /// getPositivePart - X^+ = max(X, 0).
698 const SCEV *getPositivePart(const SCEV *X) const;
699
700 /// getNegativePart - X^- = min(X, 0).
701 const SCEV *getNegativePart(const SCEV *X) const;
702
703 /// getLowerBound - Looks through all the bounds info and
704 /// computes the lower bound given the current direction settings
705 /// at each level.
706 const SCEV *getLowerBound(BoundInfo *Bound) const;
707
708 /// getUpperBound - Looks through all the bounds info and
709 /// computes the upper bound given the current direction settings
710 /// at each level.
711 const SCEV *getUpperBound(BoundInfo *Bound) const;
712
713 /// exploreDirections - Hierarchically expands the direction vector
714 /// search space, combining the directions of discovered dependences
715 /// in the DirSet field of Bound. Returns the number of distinct
716 /// dependences discovered. If the dependence is disproved,
717 /// it will return 0.
718 unsigned exploreDirections(unsigned Level, CoefficientInfo *A,
719 CoefficientInfo *B, BoundInfo *Bound,
720 const SmallBitVector &Loops,
721 unsigned &DepthExpanded, const SCEV *Delta) const;
722
723 /// testBounds - Returns true iff the current bounds are plausible.
724 bool testBounds(unsigned char DirKind, unsigned Level, BoundInfo *Bound,
725 const SCEV *Delta) const;
726
727 /// findBoundsALL - Computes the upper and lower bounds for level K
728 /// using the * direction. Records them in Bound.
729 void findBoundsALL(CoefficientInfo *A, CoefficientInfo *B, BoundInfo *Bound,
730 unsigned K) const;
731
732 /// findBoundsLT - Computes the upper and lower bounds for level K
733 /// using the < direction. Records them in Bound.
734 void findBoundsLT(CoefficientInfo *A, CoefficientInfo *B, BoundInfo *Bound,
735 unsigned K) const;
736
737 /// findBoundsGT - Computes the upper and lower bounds for level K
738 /// using the > direction. Records them in Bound.
739 void findBoundsGT(CoefficientInfo *A, CoefficientInfo *B, BoundInfo *Bound,
740 unsigned K) const;
741
742 /// findBoundsEQ - Computes the upper and lower bounds for level K
743 /// using the = direction. Records them in Bound.
744 void findBoundsEQ(CoefficientInfo *A, CoefficientInfo *B, BoundInfo *Bound,
745 unsigned K) const;
746
747 /// Given a linear access function, tries to recover subscripts
748 /// for each dimension of the array element access.
749 bool tryDelinearize(Instruction *Src, Instruction *Dst,
750 SmallVectorImpl<Subscript> &Pair);
751
752 /// Tries to delinearize \p Src and \p Dst access functions for a fixed size
753 /// multi-dimensional array. Calls delinearizeFixedSizeArray() to delinearize
754 /// \p Src and \p Dst separately,
755 bool tryDelinearizeFixedSize(Instruction *Src, Instruction *Dst,
756 const SCEV *SrcAccessFn, const SCEV *DstAccessFn,
757 SmallVectorImpl<const SCEV *> &SrcSubscripts,
758 SmallVectorImpl<const SCEV *> &DstSubscripts);
759
760 /// Tries to delinearize access function for a multi-dimensional array with
761 /// symbolic runtime sizes.
762 /// Returns true upon success and false otherwise.
763 bool
764 tryDelinearizeParametricSize(Instruction *Src, Instruction *Dst,
765 const SCEV *SrcAccessFn, const SCEV *DstAccessFn,
766 SmallVectorImpl<const SCEV *> &SrcSubscripts,
767 SmallVectorImpl<const SCEV *> &DstSubscripts);
768
769 /// checkSubscript - Helper function for checkSrcSubscript and
770 /// checkDstSubscript to avoid duplicate code
771 bool checkSubscript(const SCEV *Expr, const Loop *LoopNest,
772 SmallBitVector &Loops, bool IsSrc);
773}; // class DependenceInfo
774
775/// AnalysisPass to compute dependence information in a function
776class DependenceAnalysis : public AnalysisInfoMixin<DependenceAnalysis> {
777public:
780
781private:
784}; // class DependenceAnalysis
785
786/// Printer pass to dump DA results.
788 : public PassInfoMixin<DependenceAnalysisPrinterPass> {
789 DependenceAnalysisPrinterPass(raw_ostream &OS, bool NormalizeResults = false)
790 : OS(OS), NormalizeResults(NormalizeResults) {}
791
793
794 static bool isRequired() { return true; }
795
796private:
797 raw_ostream &OS;
798 bool NormalizeResults;
799}; // class DependenceAnalysisPrinterPass
800
801/// Legacy pass manager pass to access dependence information
803public:
804 static char ID; // Class identification, replacement for typeinfo
806
807 bool runOnFunction(Function &F) override;
808 void releaseMemory() override;
809 void getAnalysisUsage(AnalysisUsage &) const override;
810 void print(raw_ostream &, const Module * = nullptr) const override;
811 DependenceInfo &getDI() const;
812
813private:
814 std::unique_ptr<DependenceInfo> info;
815}; // class DependenceAnalysisWrapperPass
816
817/// createDependenceAnalysisPass - This creates an instance of the
818/// DependenceAnalysis wrapper pass.
820
821} // namespace llvm
822
823#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)
ArrayRef(const T &OneElt) -> ArrayRef< T >
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