BasicAA has some special bit of logic for "same base pointer" GEPs that performs a structural comparison: It only looks at two GEPs with the same base (as opposed to two GEP chains with a MustAlias base) and compares their indexes in a limited way. I generalized part of this code in D91027, and this patch merges the remainder into the normal decomposed GEP logic.
What this code ultimately wants to do is to determine that gep %base, %idx1 and gep %base, %idx2 don't alias if %idx1 != %idx2, and the access size fits within the stride.
We can express this in terms of a decomposed GEP expression with two indexes scale*%idx1 + -scale*%idx2 where %idx1 != %idx2, and some appropriate checks for sizes and offsets.
This makes the reasoning slightly more powerful, and more importantly brings all the GEP logic under a common umbrella.
You're missing the bug fix for the reasoning under recursive phis that I just landed.in bfda6941. Please add the appropriate VisitedPhiBBs.empty check to your conditions.