|
LLVM 23.0.0git
|
Class to record and manage LLVM IR flags. More...
#include "Transforms/Vectorize/VPlan.h"
Classes | |
| struct | DisjointFlagsTy |
| struct | NonNegFlagsTy |
| struct | TruncFlagsTy |
| struct | WrapFlagsTy |
Static Public Member Functions | |
| static VPIRFlags | getDefaultFlags (unsigned Opcode) |
Returns default flags for Opcode for opcodes that support it, asserts otherwise. | |
|
inline |
Definition at line 790 of file VPlan.h.
References AllFlags.
Referenced by getDefaultFlags(), intersectFlags(), transferFlags(), VPIRFlags(), llvm::VPRecipeWithIRFlags::VPRecipeWithIRFlags(), llvm::VPRecipeWithIRFlags::VPRecipeWithIRFlags(), llvm::VPReductionPHIRecipe::VPReductionPHIRecipe(), llvm::VPWidenIntOrFpInductionRecipe::VPWidenIntOrFpInductionRecipe(), and llvm::VPWidenIntOrFpInductionRecipe::VPWidenIntOrFpInductionRecipe().
|
inline |
Definition at line 792 of file VPlan.h.
References assert(), CmpPredStorage, DisjointFlags, llvm::dyn_cast(), ExactFlags, FCmpFlags, FMFs, GEP, GEPFlagsStorage, getGEPNoWrapFlags(), getPredicate(), I, NonNegFlags, llvm::Bitfield::set(), TruncFlags, VPIRFlags(), and WrapFlags.
|
inline |
Definition at line 830 of file VPlan.h.
References AllFlags, assert(), CmpPredStorage, getPredicate(), and llvm::Bitfield::set().
|
inline |
Definition at line 835 of file VPlan.h.
References AllFlags, assert(), FCmpFlags, FMFs, getPredicate(), and llvm::Bitfield::set().
|
inline |
|
inline |
Definition at line 847 of file VPlan.h.
References AllFlags, and TruncFlags.
|
inline |
|
inline |
Definition at line 856 of file VPlan.h.
References AllFlags, and DisjointFlags.
|
inline |
Definition at line 861 of file VPlan.h.
References AllFlags, and NonNegFlags.
|
inline |
Definition at line 866 of file VPlan.h.
References AllFlags, and ExactFlags.
|
inline |
Definition at line 871 of file VPlan.h.
References AllFlags, GEPFlagsStorage, and llvm::GEPNoWrapFlags::getRaw().
|
inline |
Definition at line 876 of file VPlan.h.
References AllFlags, FMFs, and ReductionFlags.
|
inline |
Apply the IR flags to I.
Definition at line 929 of file VPlan.h.
References llvm::cast(), DisjointFlags, ExactFlags, F, llvm::GEPNoWrapFlags::fromRaw(), GEPFlagsStorage, I, llvm_unreachable, NonNegFlags, TruncFlags, and WrapFlags.
Referenced by llvm::VPWidenIntrinsicRecipe::createVectorCall(), llvm::VPInstructionWithType::execute(), llvm::VPReplicateRecipe::execute(), llvm::VPWidenCallRecipe::execute(), llvm::VPWidenCastRecipe::execute(), and llvm::VPWidenRecipe::execute().
|
inline |
Drop all poison-generating flags.
Definition at line 892 of file VPlan.h.
References DisjointFlags, ExactFlags, GEPFlagsStorage, NonNegFlags, TruncFlags, and WrapFlags.
Referenced by llvm::VPlanTransforms::replaceWideCanonicalIVWithWideIV().
Returns true if the set flags are valid for Opcode.
Definition at line 2445 of file VPlanRecipes.cpp.
References llvm::VPInstruction::ComputeReductionResult, llvm_unreachable, llvm::VPInstruction::PtrAdd, llvm::VPInstruction::ReductionStartVector, llvm::VPInstruction::WideIVStep, and llvm::VPInstruction::WidePtrAdd.
Referenced by llvm::VPInstruction::execute(), and llvm::VPInstruction::VPInstruction().
Returns default flags for Opcode for opcodes that support it, asserts otherwise.
Opcodes not supporting default flags include compares and ComputeReductionResult.
Definition at line 2402 of file VPlanRecipes.cpp.
References llvm::VPInstruction::CanonicalIVIncrementForPart, llvm::VPInstruction::ComputeReductionResult, llvm_unreachable, llvm::GEPNoWrapFlags::none(), llvm::VPInstruction::PtrAdd, VPIRFlags(), and llvm::VPInstruction::WidePtrAdd.
Referenced by llvm::VPlanTransforms::convertToConcreteRecipes(), llvm::VPBuilder::createWidenCast(), hasRequiredFlagsForOpcode(), narrowToSingleScalarRecipes(), optimizeMaskToEVL(), and optimizeVectorInductionWidthForTCAndVFUF().
| FastMathFlags VPIRFlags::getFastMathFlagsOrNone | ( | ) | const |
Definition at line 390 of file VPlanRecipes.cpp.
References F, hasFastMathFlags(), llvm::FastMathFlags::setAllowContract(), llvm::FastMathFlags::setAllowReassoc(), llvm::FastMathFlags::setAllowReciprocal(), llvm::FastMathFlags::setApproxFunc(), llvm::FastMathFlags::setNoInfs(), llvm::FastMathFlags::setNoNaNs(), and llvm::FastMathFlags::setNoSignedZeros().
Referenced by llvm::VPReductionRecipe::clone(), llvm::VPScalarIVStepsRecipe::clone(), llvm::VPReductionRecipe::computeCost(), llvm::VPInstruction::execute(), llvm::VPReductionEVLRecipe::execute(), llvm::VPReductionRecipe::execute(), llvm::VPScalarIVStepsRecipe::execute(), preparePlanForEpilogueVectorLoop(), printFlags(), and llvm::VPReductionEVLRecipe::VPReductionEVLRecipe().
|
inline |
Definition at line 990 of file VPlan.h.
References llvm::GEPNoWrapFlags::fromRaw(), and GEPFlagsStorage.
Referenced by llvm::VPVectorEndPointerRecipe::clone(), llvm::VPVectorPointerRecipe::clone(), llvm::VPVectorEndPointerRecipe::execute(), llvm::VPVectorPointerRecipe::execute(), llvm::VPWidenGEPRecipe::execute(), printFlags(), and VPIRFlags().
|
inline |
Definition at line 1048 of file VPlan.h.
References hasNoSignedWrap(), and hasNoUnsignedWrap().
Referenced by llvm::VPWidenCanonicalIVRecipe::clone().
|
inline |
Definition at line 972 of file VPlan.h.
References assert(), CmpPredStorage, FCmpFlags, and llvm::Bitfield::get().
Referenced by llvm::VPReplicateRecipe::execute(), llvm::VPWidenRecipe::execute(), llvm::VPRecipeWithIRFlags::getCostForRecipeWithOpcode(), printFlags(), setPredicate(), VPIRFlags(), VPIRFlags(), and VPIRFlags().
|
inline |
Definition at line 1058 of file VPlan.h.
References assert(), and ReductionFlags.
Referenced by llvm::VPlanTransforms::handleMultiUseReductions(), and printFlags().
|
inline |
Returns true if the recipe has fast-math flags.
Definition at line 1000 of file VPlan.h.
Referenced by getFastMathFlagsOrNone().
|
inline |
|
inline |
Definition at line 1027 of file VPlan.h.
References llvm_unreachable, TruncFlags, and WrapFlags.
Referenced by getNoWrapFlags().
|
inline |
Definition at line 1016 of file VPlan.h.
References llvm_unreachable, TruncFlags, and WrapFlags.
Referenced by getNoWrapFlags().
|
inline |
Returns true if the recipe has a comparison predicate.
Definition at line 995 of file VPlan.h.
Referenced by llvm::VPReplicateRecipe::execute().
Returns true if Opcode has its required flags set.
Definition at line 2486 of file VPlanRecipes.cpp.
References llvm::VPInstruction::ComputeReductionResult, and getDefaultFlags().
Referenced by llvm::VPInstruction::execute(), and llvm::VPInstruction::VPInstruction().
Only keep flags also present in Other.
Other must have the same OpType as the current object.
Definition at line 340 of file VPlanRecipes.cpp.
References assert(), CmpPredStorage, DisjointFlags, ExactFlags, FCmpFlags, GEPFlagsStorage, NonNegFlags, ReductionFlags, TruncFlags, VPIRFlags(), and WrapFlags.
|
inline |
Definition at line 1052 of file VPlan.h.
References assert(), and DisjointFlags.
|
inline |
Definition at line 1010 of file VPlan.h.
References assert(), and NonNegFlags.
|
inline |
Definition at line 1070 of file VPlan.h.
References assert(), and ReductionFlags.
Referenced by printFlags().
|
inline |
Definition at line 1064 of file VPlan.h.
References assert(), and ReductionFlags.
Referenced by printFlags().
| void VPIRFlags::printFlags | ( | raw_ostream & | O | ) | const |
Definition at line 2590 of file VPlanRecipes.cpp.
References DisjointFlags, ExactFlags, getFastMathFlagsOrNone(), getGEPNoWrapFlags(), getPredicate(), llvm::CmpInst::getPredicateName(), getRecurKind(), isReductionInLoop(), isReductionOrdered(), NonNegFlags, llvm::FastMathFlags::print(), printRecurrenceKind(), TruncFlags, and WrapFlags.
Referenced by llvm::VPBlendRecipe::printRecipe(), llvm::VPInstruction::printRecipe(), llvm::VPInstructionWithType::printRecipe(), llvm::VPPhi::printRecipe(), llvm::VPReductionEVLRecipe::printRecipe(), llvm::VPReductionPHIRecipe::printRecipe(), llvm::VPReductionRecipe::printRecipe(), llvm::VPReplicateRecipe::printRecipe(), llvm::VPVectorEndPointerRecipe::printRecipe(), llvm::VPVectorPointerRecipe::printRecipe(), llvm::VPWidenCallRecipe::printRecipe(), llvm::VPWidenCanonicalIVRecipe::printRecipe(), llvm::VPWidenCastRecipe::printRecipe(), llvm::VPWidenGEPRecipe::printRecipe(), llvm::VPWidenIntOrFpInductionRecipe::printRecipe(), llvm::VPWidenIntrinsicRecipe::printRecipe(), and llvm::VPWidenRecipe::printRecipe().
|
inline |
Definition at line 980 of file VPlan.h.
References assert(), CmpPredStorage, FCmpFlags, getPredicate(), and llvm::Bitfield::set().
|
inline |
Definition at line 881 of file VPlan.h.
References AllFlags, and VPIRFlags().
| uint8_t llvm::VPIRFlags::AllFlags[2] |
Definition at line 786 of file VPlan.h.
Referenced by transferFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), and VPIRFlags().
| uint8_t llvm::VPIRFlags::CmpPredStorage |
Definition at line 776 of file VPlan.h.
Referenced by getPredicate(), intersectFlags(), setPredicate(), VPIRFlags(), and VPIRFlags().
| DisjointFlagsTy llvm::VPIRFlags::DisjointFlags |
Definition at line 779 of file VPlan.h.
Referenced by applyFlags(), dropPoisonGeneratingFlags(), intersectFlags(), isDisjoint(), printFlags(), VPIRFlags(), and VPIRFlags().
| ExactFlagsTy llvm::VPIRFlags::ExactFlags |
Definition at line 780 of file VPlan.h.
Referenced by applyFlags(), dropPoisonGeneratingFlags(), intersectFlags(), printFlags(), VPIRFlags(), and VPIRFlags().
| FCmpFlagsTy llvm::VPIRFlags::FCmpFlags |
Definition at line 784 of file VPlan.h.
Referenced by getPredicate(), intersectFlags(), setPredicate(), VPIRFlags(), and VPIRFlags().
| FastMathFlagsTy llvm::VPIRFlags::FMFs |
Definition at line 783 of file VPlan.h.
Referenced by llvm::VPReductionRecipe::computeCost(), VPIRFlags(), VPIRFlags(), VPIRFlags(), VPIRFlags(), llvm::VPReductionRecipe::VPReductionRecipe(), llvm::VPReductionRecipe::VPReductionRecipe(), llvm::VPReductionRecipe::VPReductionRecipe(), and llvm::VPScalarIVStepsRecipe::VPScalarIVStepsRecipe().
| uint8_t llvm::VPIRFlags::GEPFlagsStorage |
Definition at line 781 of file VPlan.h.
Referenced by applyFlags(), dropPoisonGeneratingFlags(), getGEPNoWrapFlags(), intersectFlags(), VPIRFlags(), and VPIRFlags().
| NonNegFlagsTy llvm::VPIRFlags::NonNegFlags |
Definition at line 782 of file VPlan.h.
Referenced by applyFlags(), dropPoisonGeneratingFlags(), intersectFlags(), isNonNeg(), printFlags(), VPIRFlags(), and VPIRFlags().
| ReductionFlagsTy llvm::VPIRFlags::ReductionFlags |
Definition at line 785 of file VPlan.h.
Referenced by getRecurKind(), intersectFlags(), isReductionInLoop(), isReductionOrdered(), and VPIRFlags().
| TruncFlagsTy llvm::VPIRFlags::TruncFlags |
Definition at line 778 of file VPlan.h.
Referenced by applyFlags(), dropPoisonGeneratingFlags(), hasNoSignedWrap(), hasNoUnsignedWrap(), intersectFlags(), printFlags(), VPIRFlags(), and VPIRFlags().
| WrapFlagsTy llvm::VPIRFlags::WrapFlags |
Definition at line 777 of file VPlan.h.
Referenced by applyFlags(), dropPoisonGeneratingFlags(), hasNoSignedWrap(), hasNoUnsignedWrap(), intersectFlags(), printFlags(), VPIRFlags(), and VPIRFlags().