[PATCH] D58981: CodeGenPrepare: preserve inbounds attribute when sinking GEPs
Dave Green via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Mar 12 08:00:19 PDT 2019
dmgreen added inline comments.
================
Comment at: llvm/lib/CodeGen/CodeGenPrepare.cpp:1975
+ // Conservatively reject 'inbounds' mismatches.
+ if (InBounds != other.InBounds)
+ return MultipleFields;
----------------
t.p.northover wrote:
> dmgreen wrote:
> > t.p.northover wrote:
> > > dmgreen wrote:
> > > > If one of the two is inbounds, does that not make the other inbounds? In other words, why would a mismatch in the inbounds flag matter?
> > > A violation would mean that one of the instructions produces `undef` and the other produces a known result, so I believe we could combine them by stripping off the `inbounds` attribute on the merged instruction.
> > >
> > > But personally I doubt it's worth the effort. As far as I know, front-ends don't actually mix the two (all C and C++ arithmetic is inbounds or via inttoptr/ptrtoint).
> > I thought (correct me if I'm wrong) that a violation would produce poison. And because we know the results are used in a load/store, that would be UB. So we can presume that doesn't happen, and having inbounds on one implies inbounds on the other, providing they are otherwise identical.
> >
> > I did see one example of this making a difference, although it was rather complex, quite a small change (and more often went up, not down). You are probably correct about it not being worth the effort.
> > I thought (correct me if I'm wrong) that a violation would produce poison
>
> Sorry, yes.
>
> > And because we know the results are used in a load/store, that would be UB. So we can presume that doesn't happen, and having inbounds on one implies inbounds on the other.
>
> I think we (may) know it's statically used, but there could still be a dynamic check that makes the inbounds poison innocuous but would cause bad things if the wrapping GEP suddenly became inbounds.
Yeah, I agree. Should rarely come up, and more trouble than it's worth.
Repository:
rL LLVM
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D58981/new/
https://reviews.llvm.org/D58981
More information about the llvm-commits
mailing list