[PATCH] D138874: [InstCombine] canonicalize trunc + insert as bitcast + shuffle, part 3

Dave Green via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Dec 8 01:30:42 PST 2022


dmgreen added a comment.

> Thanks for the update - so there has been some fallout.
>
> I agree that trunc+insert is simpler in the basic case. The challenge is that we haven't found any other way to solve the motivating bug. Leaving it to the backend is too late, so we need to convert a chain of inserts into a shuffle in IR to get the optimal result.
>
> This line of patches got us at least partially there. If we convert back to insert at SDAG builder/combine time, that seems like it could mitigate the problems. If that's not feasible, then I think we should revert the preceding patches in this set.

Yeah I don't know of a better way to fix it, I'm afraid. There is a quick fix for the regressions I ran into in D139611 <https://reviews.llvm.org/D139611>.


CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D138874/new/

https://reviews.llvm.org/D138874



More information about the llvm-commits mailing list