LLVM 20.0.0git
LoopVectorizationLegality.h
Go to the documentation of this file.
1//===- llvm/Transforms/Vectorize/LoopVectorizationLegality.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/// \file
10/// This file defines the LoopVectorizationLegality class. Original code
11/// in Loop Vectorizer has been moved out to its own file for modularity
12/// and reusability.
13///
14/// Currently, it works for innermost loop vectorization. Extending this to
15/// outer loop vectorization is a TODO item.
16///
17/// Also provides:
18/// 1) LoopVectorizeHints class which keeps a number of loop annotations
19/// locally for easy look up. It has the ability to write them back as
20/// loop metadata, upon request.
21/// 2) LoopVectorizationRequirements class for lazy bail out for the purpose
22/// of reporting useful failure to vectorize message.
23//
24//===----------------------------------------------------------------------===//
25
26#ifndef LLVM_TRANSFORMS_VECTORIZE_LOOPVECTORIZATIONLEGALITY_H
27#define LLVM_TRANSFORMS_VECTORIZE_LOOPVECTORIZATIONLEGALITY_H
28
29#include "llvm/ADT/MapVector.h"
33
34namespace llvm {
35class AssumptionCache;
36class BasicBlock;
37class BlockFrequencyInfo;
38class DemandedBits;
39class DominatorTree;
40class Function;
41class Loop;
42class LoopInfo;
43class Metadata;
44class OptimizationRemarkEmitter;
45class PredicatedScalarEvolution;
46class ProfileSummaryInfo;
47class TargetLibraryInfo;
48class TargetTransformInfo;
49class Type;
50
51/// Utility class for getting and setting loop vectorizer hints in the form
52/// of loop metadata.
53/// This class keeps a number of loop annotations locally (as member variables)
54/// and can, upon request, write them back as metadata on the loop. It will
55/// initially scan the loop for existing metadata, and will update the local
56/// values based on information in the loop.
57/// We cannot write all values to metadata, as the mere presence of some info,
58/// for example 'force', means a decision has been made. So, we need to be
59/// careful NOT to add them if the user hasn't specifically asked so.
61 enum HintKind {
62 HK_WIDTH,
63 HK_INTERLEAVE,
64 HK_FORCE,
65 HK_ISVECTORIZED,
66 HK_PREDICATE,
67 HK_SCALABLE
68 };
69
70 /// Hint - associates name and validation with the hint value.
71 struct Hint {
72 const char *Name;
73 unsigned Value; // This may have to change for non-numeric values.
74 HintKind Kind;
75
76 Hint(const char *Name, unsigned Value, HintKind Kind)
77 : Name(Name), Value(Value), Kind(Kind) {}
78
79 bool validate(unsigned Val);
80 };
81
82 /// Vectorization width.
83 Hint Width;
84
85 /// Vectorization interleave factor.
86 Hint Interleave;
87
88 /// Vectorization forced
89 Hint Force;
90
91 /// Already Vectorized
92 Hint IsVectorized;
93
94 /// Vector Predicate
95 Hint Predicate;
96
97 /// Says whether we should use fixed width or scalable vectorization.
98 Hint Scalable;
99
100 /// Return the loop metadata prefix.
101 static StringRef Prefix() { return "llvm.loop."; }
102
103 /// True if there is any unsafe math in the loop.
104 bool PotentiallyUnsafe = false;
105
106public:
108 FK_Undefined = -1, ///< Not selected.
109 FK_Disabled = 0, ///< Forcing disabled.
110 FK_Enabled = 1, ///< Forcing enabled.
111 };
112
114 /// Not selected.
116 /// Disables vectorization with scalable vectors.
118 /// Vectorize loops using scalable vectors or fixed-width vectors, but favor
119 /// scalable vectors when the cost-model is inconclusive. This is the
120 /// default when the scalable.enable hint is enabled through a pragma.
122 };
123
124 LoopVectorizeHints(const Loop *L, bool InterleaveOnlyWhenForced,
126 const TargetTransformInfo *TTI = nullptr);
127
128 /// Mark the loop L as already vectorized by setting the width to 1.
130
132 bool VectorizeOnlyWhenForced) const;
133
134 /// Dumps all the hint information.
135 void emitRemarkWithHints() const;
136
138 return ElementCount::get(Width.Value, (ScalableForceKind)Scalable.Value ==
140 }
141
142 unsigned getInterleave() const {
143 if (Interleave.Value)
144 return Interleave.Value;
145 // If interleaving is not explicitly set, assume that if we do not want
146 // unrolling, we also don't want any interleaving.
148 return 1;
149 return 0;
150 }
151 unsigned getIsVectorized() const { return IsVectorized.Value; }
152 unsigned getPredicate() const { return Predicate.Value; }
153 enum ForceKind getForce() const {
154 if ((ForceKind)Force.Value == FK_Undefined &&
156 return FK_Disabled;
157 return (ForceKind)Force.Value;
158 }
159
160 /// \return true if scalable vectorization has been explicitly disabled.
162 return (ScalableForceKind)Scalable.Value == SK_FixedWidthOnly;
163 }
164
165 /// If hints are provided that force vectorization, use the AlwaysPrint
166 /// pass name to force the frontend to print the diagnostic.
167 const char *vectorizeAnalysisPassName() const;
168
169 /// When enabling loop hints are provided we allow the vectorizer to change
170 /// the order of operations that is given by the scalar loop. This is not
171 /// enabled by default because can be unsafe or inefficient. For example,
172 /// reordering floating-point operations will change the way round-off
173 /// error accumulates in the loop.
174 bool allowReordering() const;
175
176 bool isPotentiallyUnsafe() const {
177 // Avoid FP vectorization if the target is unsure about proper support.
178 // This may be related to the SIMD unit in the target not handling
179 // IEEE 754 FP ops properly, or bad single-to-double promotions.
180 // Otherwise, a sequence of vectorized loops, even without reduction,
181 // could lead to different end results on the destination vectors.
182 return getForce() != LoopVectorizeHints::FK_Enabled && PotentiallyUnsafe;
183 }
184
185 void setPotentiallyUnsafe() { PotentiallyUnsafe = true; }
186
187private:
188 /// Find hints specified in the loop metadata and update local values.
189 void getHintsFromMetadata();
190
191 /// Checks string hint with one operand and set value if valid.
192 void setHint(StringRef Name, Metadata *Arg);
193
194 /// The loop these hints belong to.
195 const Loop *TheLoop;
196
197 /// Interface to emit optimization remarks.
199};
200
201/// This holds vectorization requirements that must be verified late in
202/// the process. The requirements are set by legalize and costmodel. Once
203/// vectorization has been determined to be possible and profitable the
204/// requirements can be verified by looking for metadata or compiler options.
205/// For example, some loops require FP commutativity which is only allowed if
206/// vectorization is explicitly specified or if the fast-math compiler option
207/// has been provided.
208/// Late evaluation of these requirements allows helpful diagnostics to be
209/// composed that tells the user what need to be done to vectorize the loop. For
210/// example, by specifying #pragma clang loop vectorize or -ffast-math. Late
211/// evaluation should be used only when diagnostics can generated that can be
212/// followed by a non-expert user.
214public:
215 /// Track the 1st floating-point instruction that can not be reassociated.
217 if (I && !ExactFPMathInst)
218 ExactFPMathInst = I;
219 }
220
221 Instruction *getExactFPInst() { return ExactFPMathInst; }
222
223private:
224 Instruction *ExactFPMathInst = nullptr;
225};
226
227/// LoopVectorizationLegality checks if it is legal to vectorize a loop, and
228/// to what vectorization factor.
229/// This class does not look at the profitability of vectorization, only the
230/// legality. This class has two main kinds of checks:
231/// * Memory checks - The code in canVectorizeMemory checks if vectorization
232/// will change the order of memory accesses in a way that will change the
233/// correctness of the program.
234/// * Scalars checks - The code in canVectorizeInstrs and canVectorizeMemory
235/// checks for a number of different conditions, such as the availability of a
236/// single induction variable, that all types are supported and vectorize-able,
237/// etc. This code reflects the capabilities of InnerLoopVectorizer.
238/// This class is also used by InnerLoopVectorizer for identifying
239/// induction variable and the different reduction variables.
241public:
248 : TheLoop(L), LI(LI), PSE(PSE), TTI(TTI), TLI(TLI), DT(DT), LAIs(LAIs),
249 ORE(ORE), Requirements(R), Hints(H), DB(DB), AC(AC), BFI(BFI),
250 PSI(PSI) {}
251
252 /// ReductionList contains the reduction descriptors for all
253 /// of the reductions that were found in the loop.
255
256 /// InductionList saves induction variables and maps them to the
257 /// induction descriptor.
259
260 /// RecurrenceSet contains the phi nodes that are recurrences other than
261 /// inductions and reductions.
263
264 /// Returns true if it is legal to vectorize this loop.
265 /// This does not mean that it is profitable to vectorize this
266 /// loop, only that it is legal to do so.
267 /// Temporarily taking UseVPlanNativePath parameter. If true, take
268 /// the new code path being implemented for outer loop vectorization
269 /// (should be functional for inner loop vectorization) based on VPlan.
270 /// If false, good old LV code.
271 bool canVectorize(bool UseVPlanNativePath);
272
273 /// Returns true if it is legal to vectorize the FP math operations in this
274 /// loop. Vectorizing is legal if we allow reordering of FP operations, or if
275 /// we can use in-order reductions.
276 bool canVectorizeFPMath(bool EnableStrictReductions);
277
278 /// Return true if we can vectorize this loop while folding its tail by
279 /// masking.
280 bool canFoldTailByMasking() const;
281
282 /// Mark all respective loads/stores for masking. Must only be called when
283 /// tail-folding is possible.
285
286 /// Returns the primary induction variable.
287 PHINode *getPrimaryInduction() { return PrimaryInduction; }
288
289 /// Returns the reduction variables found in the loop.
290 const ReductionList &getReductionVars() const { return Reductions; }
291
292 /// Returns the induction variables found in the loop.
293 const InductionList &getInductionVars() const { return Inductions; }
294
295 /// Return the fixed-order recurrences found in the loop.
296 RecurrenceSet &getFixedOrderRecurrences() { return FixedOrderRecurrences; }
297
298 /// Returns the widest induction type.
299 Type *getWidestInductionType() { return WidestIndTy; }
300
301 /// Returns True if given store is a final invariant store of one of the
302 /// reductions found in the loop.
304
305 /// Returns True if given address is invariant and is used to store recurrent
306 /// expression
308
309 /// Returns True if V is a Phi node of an induction variable in this loop.
310 bool isInductionPhi(const Value *V) const;
311
312 /// Returns a pointer to the induction descriptor, if \p Phi is an integer or
313 /// floating point induction.
315
316 /// Returns a pointer to the induction descriptor, if \p Phi is pointer
317 /// induction.
319
320 /// Returns True if V is a cast that is part of an induction def-use chain,
321 /// and had been proven to be redundant under a runtime guard (in other
322 /// words, the cast has the same SCEV expression as the induction phi).
323 bool isCastedInductionVariable(const Value *V) const;
324
325 /// Returns True if V can be considered as an induction variable in this
326 /// loop. V can be the induction phi, or some redundant cast in the def-use
327 /// chain of the inducion phi.
328 bool isInductionVariable(const Value *V) const;
329
330 /// Returns True if PN is a reduction variable in this loop.
331 bool isReductionVariable(PHINode *PN) const { return Reductions.count(PN); }
332
333 /// Returns True if Phi is a fixed-order recurrence in this loop.
334 bool isFixedOrderRecurrence(const PHINode *Phi) const;
335
336 /// Return true if the block BB needs to be predicated in order for the loop
337 /// to be vectorized.
338 bool blockNeedsPredication(BasicBlock *BB) const;
339
340 /// Check if this pointer is consecutive when vectorizing. This happens
341 /// when the last index of the GEP is the induction variable, or that the
342 /// pointer itself is an induction variable.
343 /// This check allows us to vectorize A[idx] into a wide load/store.
344 /// Returns:
345 /// 0 - Stride is unknown or non-consecutive.
346 /// 1 - Address is consecutive.
347 /// -1 - Address is consecutive, and decreasing.
348 /// NOTE: This method must only be used before modifying the original scalar
349 /// loop. Do not use after invoking 'createVectorizedLoopSkeleton' (PR34965).
350 int isConsecutivePtr(Type *AccessTy, Value *Ptr) const;
351
352 /// Returns true if \p V is invariant across all loop iterations according to
353 /// SCEV.
354 bool isInvariant(Value *V) const;
355
356 /// Returns true if value V is uniform across \p VF lanes, when \p VF is
357 /// provided, and otherwise if \p V is invariant across all loop iterations.
358 bool isUniform(Value *V, ElementCount VF) const;
359
360 /// A uniform memory op is a load or store which accesses the same memory
361 /// location on all \p VF lanes, if \p VF is provided and otherwise if the
362 /// memory location is invariant.
363 bool isUniformMemOp(Instruction &I, ElementCount VF) const;
364
365 /// Returns the information that we collected about runtime memory check.
367 return LAI->getRuntimePointerChecking();
368 }
369
370 const LoopAccessInfo *getLAI() const { return LAI; }
371
374 }
375
378 }
379
380 /// Returns true if vector representation of the instruction \p I
381 /// requires mask.
382 bool isMaskRequired(const Instruction *I) const {
383 return MaskedOp.contains(I);
384 }
385
386 /// Returns true if there is at least one function call in the loop which
387 /// has a vectorized variant available.
388 bool hasVectorCallVariants() const { return VecCallVariantsFound; }
389
390 unsigned getNumStores() const { return LAI->getNumStores(); }
391 unsigned getNumLoads() const { return LAI->getNumLoads(); }
392
394 return &PSE;
395 }
396
397 Loop *getLoop() const { return TheLoop; }
398
399 LoopInfo *getLoopInfo() const { return LI; }
400
401 AssumptionCache *getAssumptionCache() const { return AC; }
402
403 ScalarEvolution *getScalarEvolution() const { return PSE.getSE(); }
404
405 DominatorTree *getDominatorTree() const { return DT; }
406
407private:
408 /// Return true if the pre-header, exiting and latch blocks of \p Lp and all
409 /// its nested loops are considered legal for vectorization. These legal
410 /// checks are common for inner and outer loop vectorization.
411 /// Temporarily taking UseVPlanNativePath parameter. If true, take
412 /// the new code path being implemented for outer loop vectorization
413 /// (should be functional for inner loop vectorization) based on VPlan.
414 /// If false, good old LV code.
415 bool canVectorizeLoopNestCFG(Loop *Lp, bool UseVPlanNativePath);
416
417 /// Set up outer loop inductions by checking Phis in outer loop header for
418 /// supported inductions (int inductions). Return false if any of these Phis
419 /// is not a supported induction or if we fail to find an induction.
420 bool setupOuterLoopInductions();
421
422 /// Return true if the pre-header, exiting and latch blocks of \p Lp
423 /// (non-recursive) are considered legal for vectorization.
424 /// Temporarily taking UseVPlanNativePath parameter. If true, take
425 /// the new code path being implemented for outer loop vectorization
426 /// (should be functional for inner loop vectorization) based on VPlan.
427 /// If false, good old LV code.
428 bool canVectorizeLoopCFG(Loop *Lp, bool UseVPlanNativePath);
429
430 /// Check if a single basic block loop is vectorizable.
431 /// At this point we know that this is a loop with a constant trip count
432 /// and we only need to check individual instructions.
433 bool canVectorizeInstrs();
434
435 /// When we vectorize loops we may change the order in which
436 /// we read and write from memory. This method checks if it is
437 /// legal to vectorize the code, considering only memory constrains.
438 /// Returns true if the loop is vectorizable
439 bool canVectorizeMemory();
440
441 /// Return true if we can vectorize this loop using the IF-conversion
442 /// transformation.
443 bool canVectorizeWithIfConvert();
444
445 /// Return true if we can vectorize this outer loop. The method performs
446 /// specific checks for outer loop vectorization.
447 bool canVectorizeOuterLoop();
448
449 /// Return true if all of the instructions in the block can be speculatively
450 /// executed, and record the loads/stores that require masking.
451 /// \p SafePtrs is a list of addresses that are known to be legal and we know
452 /// that we can read from them without segfault.
453 /// \p MaskedOp is a list of instructions that have to be transformed into
454 /// calls to the appropriate masked intrinsic when the loop is vectorized
455 /// or dropped if the instruction is a conditional assume intrinsic.
456 bool
457 blockCanBePredicated(BasicBlock *BB, SmallPtrSetImpl<Value *> &SafePtrs,
459
460 /// Updates the vectorization state by adding \p Phi to the inductions list.
461 /// This can set \p Phi as the main induction of the loop if \p Phi is a
462 /// better choice for the main induction than the existing one.
463 void addInductionPhi(PHINode *Phi, const InductionDescriptor &ID,
464 SmallPtrSetImpl<Value *> &AllowedExit);
465
466 /// The loop that we evaluate.
467 Loop *TheLoop;
468
469 /// Loop Info analysis.
470 LoopInfo *LI;
471
472 /// A wrapper around ScalarEvolution used to add runtime SCEV checks.
473 /// Applies dynamic knowledge to simplify SCEV expressions in the context
474 /// of existing SCEV assumptions. The analysis will also add a minimal set
475 /// of new predicates if this is required to enable vectorization and
476 /// unrolling.
478
479 /// Target Transform Info.
481
482 /// Target Library Info.
484
485 /// Dominator Tree.
486 DominatorTree *DT;
487
488 // LoopAccess analysis.
490
491 const LoopAccessInfo *LAI = nullptr;
492
493 /// Interface to emit optimization remarks.
495
496 // --- vectorization state --- //
497
498 /// Holds the primary induction variable. This is the counter of the
499 /// loop.
500 PHINode *PrimaryInduction = nullptr;
501
502 /// Holds the reduction variables.
503 ReductionList Reductions;
504
505 /// Holds all of the induction variables that we found in the loop.
506 /// Notice that inductions don't need to start at zero and that induction
507 /// variables can be pointers.
508 InductionList Inductions;
509
510 /// Holds all the casts that participate in the update chain of the induction
511 /// variables, and that have been proven to be redundant (possibly under a
512 /// runtime guard). These casts can be ignored when creating the vectorized
513 /// loop body.
514 SmallPtrSet<Instruction *, 4> InductionCastsToIgnore;
515
516 /// Holds the phi nodes that are fixed-order recurrences.
517 RecurrenceSet FixedOrderRecurrences;
518
519 /// Holds the widest induction type encountered.
520 Type *WidestIndTy = nullptr;
521
522 /// Allowed outside users. This holds the variables that can be accessed from
523 /// outside the loop.
524 SmallPtrSet<Value *, 4> AllowedExit;
525
526 /// Vectorization requirements that will go through late-evaluation.
527 LoopVectorizationRequirements *Requirements;
528
529 /// Used to emit an analysis of any legality issues.
530 LoopVectorizeHints *Hints;
531
532 /// The demanded bits analysis is used to compute the minimum type size in
533 /// which a reduction can be computed.
534 DemandedBits *DB;
535
536 /// The assumption cache analysis is used to compute the minimum type size in
537 /// which a reduction can be computed.
538 AssumptionCache *AC;
539
540 /// While vectorizing these instructions we have to generate a
541 /// call to the appropriate masked intrinsic or drop them in case of
542 /// conditional assumes.
544
545 /// BFI and PSI are used to check for profile guided size optimizations.
548
549 /// If we discover function calls within the loop which have a valid
550 /// vectorized variant, record that fact so that LoopVectorize can
551 /// (potentially) make a better decision on the maximum VF and enable
552 /// the use of those function variants.
553 bool VecCallVariantsFound = false;
554};
555
556} // namespace llvm
557
558#endif // LLVM_TRANSFORMS_VECTORIZE_LOOPVECTORIZATIONLEGALITY_H
RelocType Type
Definition: COFFYAML.cpp:391
std::string Name
#define F(x, y, z)
Definition: MD5.cpp:55
#define I(x, y, z)
Definition: MD5.cpp:58
#define H(x, y, z)
Definition: MD5.cpp:57
This file implements a map that provides insertion order iteration.
A cache of @llvm.assume calls within a function.
LLVM Basic Block Representation.
Definition: BasicBlock.h:61
BlockFrequencyInfo pass uses BlockFrequencyInfoImpl implementation to estimate IR basic block frequen...
Concrete subclass of DominatorTreeBase that is used to compute a normal dominator tree.
Definition: Dominators.h:162
static constexpr ElementCount get(ScalarTy MinVal, bool Scalable)
Definition: TypeSize.h:317
A struct for saving information about induction variables.
Drive the analysis of memory accesses in the loop.
const MemoryDepChecker & getDepChecker() const
the Memory Dependence Checker which can determine the loop-independent and loop-carried dependences b...
const RuntimePointerChecking * getRuntimePointerChecking() const
unsigned getNumLoads() const
unsigned getNumStores() const
LoopVectorizationLegality checks if it is legal to vectorize a loop, and to what vectorization factor...
MapVector< PHINode *, InductionDescriptor > InductionList
InductionList saves induction variables and maps them to the induction descriptor.
bool isInvariantStoreOfReduction(StoreInst *SI)
Returns True if given store is a final invariant store of one of the reductions found in the loop.
bool hasVectorCallVariants() const
Returns true if there is at least one function call in the loop which has a vectorized variant availa...
RecurrenceSet & getFixedOrderRecurrences()
Return the fixed-order recurrences found in the loop.
bool isInvariantAddressOfReduction(Value *V)
Returns True if given address is invariant and is used to store recurrent expression.
bool blockNeedsPredication(BasicBlock *BB) const
Return true if the block BB needs to be predicated in order for the loop to be vectorized.
bool canVectorize(bool UseVPlanNativePath)
Returns true if it is legal to vectorize this loop.
PredicatedScalarEvolution * getPredicatedScalarEvolution() const
int isConsecutivePtr(Type *AccessTy, Value *Ptr) const
Check if this pointer is consecutive when vectorizing.
AssumptionCache * getAssumptionCache() const
SmallPtrSet< const PHINode *, 8 > RecurrenceSet
RecurrenceSet contains the phi nodes that are recurrences other than inductions and reductions.
bool canVectorizeFPMath(bool EnableStrictReductions)
Returns true if it is legal to vectorize the FP math operations in this loop.
LoopVectorizationLegality(Loop *L, PredicatedScalarEvolution &PSE, DominatorTree *DT, TargetTransformInfo *TTI, TargetLibraryInfo *TLI, Function *F, LoopAccessInfoManager &LAIs, LoopInfo *LI, OptimizationRemarkEmitter *ORE, LoopVectorizationRequirements *R, LoopVectorizeHints *H, DemandedBits *DB, AssumptionCache *AC, BlockFrequencyInfo *BFI, ProfileSummaryInfo *PSI)
bool isReductionVariable(PHINode *PN) const
Returns True if PN is a reduction variable in this loop.
bool isFixedOrderRecurrence(const PHINode *Phi) const
Returns True if Phi is a fixed-order recurrence in this loop.
const InductionDescriptor * getPointerInductionDescriptor(PHINode *Phi) const
Returns a pointer to the induction descriptor, if Phi is pointer induction.
const InductionDescriptor * getIntOrFpInductionDescriptor(PHINode *Phi) const
Returns a pointer to the induction descriptor, if Phi is an integer or floating point induction.
bool isInductionPhi(const Value *V) const
Returns True if V is a Phi node of an induction variable in this loop.
PHINode * getPrimaryInduction()
Returns the primary induction variable.
bool isUniform(Value *V, ElementCount VF) const
Returns true if value V is uniform across VF lanes, when VF is provided, and otherwise if V is invari...
const InductionList & getInductionVars() const
Returns the induction variables found in the loop.
bool isInvariant(Value *V) const
Returns true if V is invariant across all loop iterations according to SCEV.
const ReductionList & getReductionVars() const
Returns the reduction variables found in the loop.
bool canFoldTailByMasking() const
Return true if we can vectorize this loop while folding its tail by masking.
void prepareToFoldTailByMasking()
Mark all respective loads/stores for masking.
Type * getWidestInductionType()
Returns the widest induction type.
const LoopAccessInfo * getLAI() const
MapVector< PHINode *, RecurrenceDescriptor > ReductionList
ReductionList contains the reduction descriptors for all of the reductions that were found in the loo...
ScalarEvolution * getScalarEvolution() const
bool isUniformMemOp(Instruction &I, ElementCount VF) const
A uniform memory op is a load or store which accesses the same memory location on all VF lanes,...
bool isMaskRequired(const Instruction *I) const
Returns true if vector representation of the instruction I requires mask.
const RuntimePointerChecking * getRuntimePointerChecking() const
Returns the information that we collected about runtime memory check.
bool isInductionVariable(const Value *V) const
Returns True if V can be considered as an induction variable in this loop.
bool isCastedInductionVariable(const Value *V) const
Returns True if V is a cast that is part of an induction def-use chain, and had been proven to be red...
This holds vectorization requirements that must be verified late in the process.
void addExactFPMathInst(Instruction *I)
Track the 1st floating-point instruction that can not be reassociated.
Utility class for getting and setting loop vectorizer hints in the form of loop metadata.
@ SK_PreferScalable
Vectorize loops using scalable vectors or fixed-width vectors, but favor scalable vectors when the co...
@ SK_FixedWidthOnly
Disables vectorization with scalable vectors.
bool allowVectorization(Function *F, Loop *L, bool VectorizeOnlyWhenForced) const
bool allowReordering() const
When enabling loop hints are provided we allow the vectorizer to change the order of operations that ...
void emitRemarkWithHints() const
Dumps all the hint information.
void setAlreadyVectorized()
Mark the loop L as already vectorized by setting the width to 1.
const char * vectorizeAnalysisPassName() const
If hints are provided that force vectorization, use the AlwaysPrint pass name to force the frontend t...
Represents a single loop in the control flow graph.
Definition: LoopInfo.h:44
size_type count(const KeyT &Key) const
Definition: MapVector.h:165
bool isSafeForAnyVectorWidth() const
Return true if the number of elements that are safe to operate on simultaneously is not bounded.
uint64_t getMaxSafeVectorWidthInBits() const
Return the number of elements that are safe to operate on simultaneously, multiplied by the size of t...
Root of the metadata hierarchy.
Definition: Metadata.h:62
The optimization diagnostic interface.
An interface layer with SCEV used to manage how we see SCEV expressions for values in the context of ...
ScalarEvolution * getSE() const
Returns the ScalarEvolution analysis used.
Analysis providing profile information.
Holds information about the memory runtime legality checks to verify that a group of pointers do not ...
The main scalar evolution driver.
A templated base class for SmallPtrSet which provides the typesafe interface that is common across al...
Definition: SmallPtrSet.h:347
An instruction for storing to memory.
Definition: Instructions.h:290
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:50
Provides information about what library functions are available for the current target.
This pass provides access to the codegen interfaces that are needed for IR-level transformations.
The instances of the Type class are immutable: once they are created, they are never changed.
Definition: Type.h:45
LLVM Value Representation.
Definition: Value.h:74
@ BasicBlock
Various leaf nodes.
Definition: ISDOpcodes.h:71
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
bool hasDisableAllTransformsHint(const Loop *L)
Look for the loop attribute that disables all transformation heuristic.
Definition: LoopUtils.cpp:344
TransformationMode hasUnrollTransformation(const Loop *L)
Definition: LoopUtils.cpp:352
@ TM_Disable
The transformation should not be applied.
Definition: LoopUtils.h:286