The following example:
define i8 @foo(i8 %v) local_unnamed_addr #0 {
region.0:
%0 = mul nsw i8 16, %v %1 = mul nsw i8 0, %0 %2 = mul nsw i8 1, %1 ret i8 %2
}
Causes nary reassociation to fall into infinite loop.
The root cause is in overflowed SCEV expression (16*v)*(16*v) - which is 0 for "i8" type.
The patch inserts a check to avoid the case.
If I hadn't read the description, I'd have no idea what this meant (and I'm still not entirely sure). How does this detect overflow? Is it fair to say that x*0 is a special case because it can be replicated arbitrarily-many times in products (because it is equal to 0, and thus, so is any product of which it is a part), and that can lead to infinite loops.