[PATCH] D124158: [Clang][Attr] Skip adding noundef attribute to arguments when function has convergent attribute
Johannes Doerfert via Phabricator via cfe-commits
cfe-commits at lists.llvm.org
Mon May 2 10:39:34 PDT 2022
jdoerfert added a comment.
In D124158#3480566 <https://reviews.llvm.org/D124158#3480566>, @efriedma wrote:
> In D124158#3480384 <https://reviews.llvm.org/D124158#3480384>, @arsenm wrote:
>
>> I'm thinking noundef is a bit of red herring here. The real problem seems to be arising from the assume call which is inserted, which now introduces the assumption that the lane ID must be 0
>
> The optimizer is creating the llvm.assume call based on the violation of the noundef attribute.
I agree. As far as I can tell you have two options, both are specific to the shuffle functions:
1. Do not set noundef for calls to them as they allow undef values for all lanes we don't read the value.
2. Freeze the inputs unconditionally.
Convergent is unrelated to this.
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D124158/new/
https://reviews.llvm.org/D124158
More information about the cfe-commits
mailing list