LLVM 20.0.0git
|
This holds vectorization requirements that must be verified late in the process. More...
#include "llvm/Transforms/Vectorize/LoopVectorizationLegality.h"
Public Member Functions | |
void | addExactFPMathInst (Instruction *I) |
Track the 1st floating-point instruction that can not be reassociated. | |
Instruction * | getExactFPInst () |
This holds vectorization requirements that must be verified late in the process.
The requirements are set by legalize and costmodel. Once vectorization has been determined to be possible and profitable the requirements can be verified by looking for metadata or compiler options. For example, some loops require FP commutativity which is only allowed if vectorization is explicitly specified or if the fast-math compiler option has been provided. Late evaluation of these requirements allows helpful diagnostics to be composed that tells the user what need to be done to vectorize the loop. For example, by specifying #pragma clang loop vectorize or -ffast-math. Late evaluation should be used only when diagnostics can generated that can be followed by a non-expert user.
Definition at line 213 of file LoopVectorizationLegality.h.
|
inline |
Track the 1st floating-point instruction that can not be reassociated.
Definition at line 216 of file LoopVectorizationLegality.h.
References I.
|
inline |
Definition at line 221 of file LoopVectorizationLegality.h.
Referenced by llvm::LoopVectorizationLegality::canVectorizeFPMath(), and llvm::LoopVectorizePass::processLoop().