We should check if loop size allows us to peel at least one iteration before we do so.
Details
Diff Detail
Event Timeline
LGTM with a style nit.
lib/Transforms/Utils/LoopUnrollPeel.cpp | ||
---|---|---|
91 | I would combine this into a single if with a &&, rather than two nested ones. |
lib/Transforms/Utils/LoopUnrollPeel.cpp | ||
---|---|---|
91 | We can't combine it with variable's declaration, and declaring the latch externally looks quite ugly. |
lib/Transforms/Utils/LoopUnrollPeel.cpp | ||
---|---|---|
91 | I think having another level of nesting here is worse than declaring the latch externally. |
lib/Transforms/Utils/LoopUnrollPeel.cpp | ||
---|---|---|
91 | I just realized that getLoopPatch never returns null, and this is ensured within isLoopSimplifyForm in canPeel method. So I will replace the condition here and make an assert for latch. |
LGTM.
Also, forgot it before, sorry - please add a test. (No need for a huge test, you can force a small threshold.)
I would combine this into a single if with a &&, rather than two nested ones.