diff options
author | Chandler Carruth <chandlerc@gmail.com> | 2018-05-30 02:46:45 +0000 |
---|---|---|
committer | Chandler Carruth <chandlerc@gmail.com> | 2018-05-30 02:46:45 +0000 |
commit | 71fd27043ee0c8e1b9a1a71aeab7d5629a7b29f1 (patch) | |
tree | 95552b9d57811ca8df5476109b9554baa76871e0 /clang/lib/Frontend/CompilerInvocation.cpp | |
parent | e9bdfc16d76c23e9c0c9f470fef190ba631cc7cc (diff) | |
download | bcm5719-llvm-71fd27043ee0c8e1b9a1a71aeab7d5629a7b29f1.tar.gz bcm5719-llvm-71fd27043ee0c8e1b9a1a71aeab7d5629a7b29f1.zip |
[PM/LoopUnswitch] When using the new SimpleLoopUnswitch pass, schedule
loop-cleanup passes at the beginning of the loop pass pipeline, and
re-enqueue loops after even trivial unswitching.
This will allow us to much more consistently avoid simplifying code
while doing trivial unswitching. I've also added a test case that
specifically shows effective iteration using this technique.
I've unconditionally updated the new PM as that is always using the
SimpleLoopUnswitch pass, and I've made the pipeline changes for the old
PM conditional on using this new unswitch pass. I added a bunch of
comments to the loop pass pipeline in the old PM to make it more clear
what is going on when reviewing.
Hopefully this will unblock doing *partial* unswitching instead of just
full unswitching.
Differential Revision: https://reviews.llvm.org/D47408
llvm-svn: 333493
Diffstat (limited to 'clang/lib/Frontend/CompilerInvocation.cpp')
0 files changed, 0 insertions, 0 deletions