summaryrefslogtreecommitdiffstats
path: root/clang/lib/Frontend/CompilerInvocation.cpp
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2018-05-30 02:46:45 +0000
committerChandler Carruth <chandlerc@gmail.com>2018-05-30 02:46:45 +0000
commit71fd27043ee0c8e1b9a1a71aeab7d5629a7b29f1 (patch)
tree95552b9d57811ca8df5476109b9554baa76871e0 /clang/lib/Frontend/CompilerInvocation.cpp
parente9bdfc16d76c23e9c0c9f470fef190ba631cc7cc (diff)
downloadbcm5719-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
OpenPOWER on IntegriCloud