This is an alternative to D99759 to avoid the compile-time explosion seen in:
https://llvm.org/PR49785
The suggestion was to make the exclusion logic stronger to avoid blowing up, but I'm not seeing how to do that. Note that we reduced the complexity of the exclusion mechanism in D16204 because it was too costly.
So I'm questioning the need for recursion/exclusion entirely - what is the optimization value vs. cost of recursively computing known bits based on assumptions? This was built into the implementation from the start with 60db058, and we have kept adding code/cost to deal with that capability.
By clearing the query's AssumptionCache inside computeKnownBitsFromAssume(), this patch retains all existing assume functionality except refining known bits based on even more assumptions.
We have 1 regression test that shows a difference in optimization power. Is that example representative of real-world llvm.assume usage?
clang-format: please reformat the code