diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2023-07-26 19:03:47 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2023-07-26 19:04:23 +0000 | 
| commit | 7fa27ce4a07f19b07799a767fc29416f3b625afb (patch) | |
| tree | 27825c83636c4de341eb09a74f49f5d38a15d165 /llvm/lib/Transforms/Vectorize/VPlanTransforms.h | |
| parent | e3b557809604d036af6e00c60f012c2025b59a5e (diff) | |
Diffstat (limited to 'llvm/lib/Transforms/Vectorize/VPlanTransforms.h')
| -rw-r--r-- | llvm/lib/Transforms/Vectorize/VPlanTransforms.h | 29 | 
1 files changed, 21 insertions, 8 deletions
| diff --git a/llvm/lib/Transforms/Vectorize/VPlanTransforms.h b/llvm/lib/Transforms/Vectorize/VPlanTransforms.h index be0d8e76d809..3eccf6e9600d 100644 --- a/llvm/lib/Transforms/Vectorize/VPlanTransforms.h +++ b/llvm/lib/Transforms/Vectorize/VPlanTransforms.h @@ -25,23 +25,23 @@ class ScalarEvolution;  class Loop;  class PredicatedScalarEvolution;  class TargetLibraryInfo; +class VPBuilder; +class VPRecipeBuilder;  struct VPlanTransforms {    /// Replaces the VPInstructions in \p Plan with corresponding    /// widen recipes.    static void -  VPInstructionsToVPRecipes(Loop *OrigLoop, VPlanPtr &Plan, +  VPInstructionsToVPRecipes(VPlanPtr &Plan,                              function_ref<const InductionDescriptor *(PHINode *)>                                  GetIntOrFpInductionDescriptor, -                            SmallPtrSetImpl<Instruction *> &DeadInstructions,                              ScalarEvolution &SE, const TargetLibraryInfo &TLI); -  static bool sinkScalarOperands(VPlan &Plan); - -  /// Merge replicate regions in their successor region, if a replicate region -  /// is connected to a successor replicate region with the same predicate by a -  /// single, empty VPBasicBlock. -  static bool mergeReplicateRegionsIntoSuccessors(VPlan &Plan); +  /// Wrap predicated VPReplicateRecipes with a mask operand in an if-then +  /// region block and remove the mask operand. Optimize the created regions by +  /// iteratively sinking scalar operands into the region, followed by merging +  /// regions until no improvements are remaining. +  static void createAndOptimizeReplicateRegions(VPlan &Plan);    /// Remove redundant VPBasicBlocks by merging them into their predecessor if    /// the predecessor has a single successor. @@ -71,6 +71,19 @@ struct VPlanTransforms {    /// them with already existing recipes expanding the same SCEV expression.    static void removeRedundantExpandSCEVRecipes(VPlan &Plan); +  /// Sink users of fixed-order recurrences after the recipe defining their +  /// previous value. Then introduce FirstOrderRecurrenceSplice VPInstructions +  /// to combine the value from the recurrence phis and previous values. The +  /// current implementation assumes all users can be sunk after the previous +  /// value, which is enforced by earlier legality checks. +  /// \returns true if all users of fixed-order recurrences could be re-arranged +  /// as needed or false if it is not possible. In the latter case, \p Plan is +  /// not valid. +  static bool adjustFixedOrderRecurrences(VPlan &Plan, VPBuilder &Builder); + +  /// Clear NSW/NUW flags from reduction instructions if necessary. +  static void clearReductionWrapFlags(VPlan &Plan); +    /// Optimize \p Plan based on \p BestVF and \p BestUF. This may restrict the    /// resulting plan to \p BestVF and \p BestUF.    static void optimizeForVFAndUF(VPlan &Plan, ElementCount BestVF, | 
