[PATCH] D115261: [LV] Disable runtime unrolling for vectorized loops.
Philip Reames via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Dec 10 09:32:36 PST 2021
reames added a comment.
In D115261#3185855 <https://reviews.llvm.org/D115261#3185855>, @fhahn wrote:
> In D115261#3185784 <https://reviews.llvm.org/D115261#3185784>, @reames wrote:
>
>> @fhahn Can you point to a couple other cases where this is needed for profitability? I took a look at PR40961, and that really looks more like a problem us figuring out small trip counts and restricting transforms appropriately. (i.e. the unroller should never be unrolling longer than the total loop trip count) That's "easily" fixable, and we should do so.
>
> Yeah some of the issues are related to SCEV missing trip counts and a couple of those have been fixed. That was one of the original motivations for the `applyLoopGuards` logic in SCEV. Unfortunately I am not able to find the other issue in the bug tracker I was thinking about just now.
>
> But one different example is https://godbolt.org/z/7cE9soTa9 with a dependency on the accumulator registers
So, looking at the codegen for that one, the unrolled form doesn't really look terrible. For a unknown trip count loop without profiling available, unrolling here seems fairly neutral perf wise (or at least I'd guess so). Codesize is definitely a regression. Can you explain why it is that unrolling is strictly unprofitable here? I have a bad feeling that this is only indirectly an interaction with the vectorizer, and there's some alternate framing here. I want to see your explanation to see what might fall out.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D115261/new/
https://reviews.llvm.org/D115261
More information about the llvm-commits
mailing list