The SCEV code for constructing GEP expressions currently assumes that the addition of the base and all the offsets is nsw if the GEP is inbounds. While the addition of the offsets is indeed nsw, the addition to the base address is not, as the base address is interpreted as an unsigned value (gep inbounds 0x7fffffff, 1 is legal).
Fix the GEP expression code to not assume nsw for the base+offset calculation. However, do assume nuw if we know that the offset is non-negative. With this, we use the same behavior as the construction of GEP addrecs does. (Modulo the fact that we disregard SCEV unification, as the pre-existing FIXME points out).
How about case when gep has no inbounds flag, but we can prove that base+ offset does not sign-wrap? Likewise, we could prove that base + offset does not unsign-wrap even without non-negative fact for offset in some cases. Why don't we use isKnownPredicate(slt/ult, base, base + offset) (at least in affine case)?