This patch exploits the knowledge that we may be running many fewer than bitwidth iterations of the loop, and may be able to disallow the overflow case. This patch specifically implements only the shl case, but this can be generalized to ashr and lshr without difficulty.
In my motivating example (a multiple dimension loop nest w/a shl recurrence at the outer level), this results in a massive improvement in scev-aa results.
clang-format: please reformat the code
-ConstantRange ScalarEvolution:: -getRangeForUnknownRecurrence(const SCEVUnknown *U) { +ConstantRange +ScalarEvolution::getRangeForUnknownRecurrence(const SCEVUnknown *U) {