diff options
author | Ayal Zaks <ayal.zaks@intel.com> | 2017-05-23 07:08:02 +0000 |
---|---|---|
committer | Ayal Zaks <ayal.zaks@intel.com> | 2017-05-23 07:08:02 +0000 |
commit | f93293ef42e631c826fa830d2487d73d9543425d (patch) | |
tree | 01cfae5a65ba826595d754b9311ccdafbe9c25c5 /docs | |
parent | 893c346e0c6ad755f081a7c34abdeea1c6911d18 (diff) |
[LV] Report multiple reasons for not vectorizing under allowExtraAnalysis
The default behavior of -Rpass-analysis=loop-vectorizer is to report only the
first reason encountered for not vectorizing, if one is found, at which time the
vectorizer aborts its handling of the loop. This patch allows multiple reasons
for not vectorizing to be identified and reported, at the potential expense of
additional compile-time, under allowExtraAnalysis which can currently be turned
on by Clang's -fsave-optimization-record and opt's -pass-remarks-missed.
Removed from LoopVectorizationLegality::canVectorize() the redundant checking
and reporting if we CantComputeNumberOfIterations, as LAI::canAnalyzeLoop() also
does that. This redundancy is caught by a lit test once multiple reasons are
reported.
Patch initially developed by Dror Barak.
Differential Revision: https://reviews.llvm.org/D33396
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@303613 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'docs')
-rw-r--r-- | docs/Vectorizers.rst | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/docs/Vectorizers.rst b/docs/Vectorizers.rst index 65c19aa2bc0c..a909d458c317 100644 --- a/docs/Vectorizers.rst +++ b/docs/Vectorizers.rst @@ -99,7 +99,9 @@ Optimization remarks are enabled using: indicates if vectorization was specified. ``-Rpass-analysis=loop-vectorize`` identifies the statements that caused -vectorization to fail. +vectorization to fail. If in addition ``-fsave-optimization-record`` is +provided, multiple causes of vectorization failure may be listed (this behavior +might change in the future). Consider the following loop: |