[PATCH] D104795: [IVDescriptors] Make pointer inductions compatible with opaque pointers
Arthur Eubanks via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Thu Jul 15 10:40:08 PDT 2021
aeubanks added inline comments.
================
Comment at: llvm/lib/Analysis/IVDescriptors.cpp:1272
+ // We need a GEP to determine the element type.
+ GEPOperator *GEP =
+ dyn_cast<GEPOperator>(Phi->getIncomingValueForBlock(Latch));
----------------
a.elovikov wrote:
> a.elovikov wrote:
> > Would it work if we'd have a chain of geps with different srcElementTypes? E.g. something like
> >
> > %ptr = phi [ %from.preheader ], [ ptr.next ]
> > %gep = getelementptr i16, %ptr, 1
> > %ptr.next = getelementptr i32, %gep, 1
> >
> > The step isn't even representable in multiples of i32 in that scenario.
> @aeubanks , why can't this happen? Or, if it can, why isn't it an issue?
I'm not super familiar with this code, but it looks like each InductionDescriptor describes a single induction. So each GEP would have its own InductionDescriptor?
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D104795/new/
https://reviews.llvm.org/D104795
More information about the llvm-commits
mailing list