summaryrefslogtreecommitdiffstats
path: root/llvm/tools/llvm-pdbutil/ExplainOutputStyle.cpp
diff options
context:
space:
mode:
authorHaicheng Wu <haicheng@codeaurora.org>2018-03-29 16:01:26 +0000
committerHaicheng Wu <haicheng@codeaurora.org>2018-03-29 16:01:26 +0000
commitc7cc87922e7e28487fd93b010d6de9ec7c0ef318 (patch)
treed9b77d6169dd851e16a4104e56c710d79b0a9a36 /llvm/tools/llvm-pdbutil/ExplainOutputStyle.cpp
parent0132baad7e0e2054a43469b00635f23801cba68b (diff)
downloadbcm5719-llvm-c7cc87922e7e28487fd93b010d6de9ec7c0ef318.tar.gz
bcm5719-llvm-c7cc87922e7e28487fd93b010d6de9ec7c0ef318.zip
[JumpThreading] Don't select an edge that we know we can't thread
In r312664 (D36404), JumpThreading stopped threading edges into loop headers. Unfortunately, I observed a significant performance regression as a result of this change. Upon further investigation, the problematic pattern looked something like this (after many high level optimizations): while (true) { bool cond = ...; if (!cond) { <body> } if (cond) break; } Now, naturally we want jump threading to essentially eliminate the second if check and hook up the edges appropriately. However, the above mentioned change, prevented it from doing this because it would have to thread an edge into the loop header. Upon further investigation, what is happening is that since both branches are threadable, JumpThreading picks one of them at arbitrarily. In my case, because of the way that the IR ended up, it tended to pick the one to the loop header, bailing out immediately after. However, if it had picked the one to the exit block, everything would have worked out fine (because the only remaining branch would then be folded, not thraded which is acceptable). Thus, to fix this problem, we can simply eliminate loop headers from consideration as possible threading targets earlier, to make sure that if there are multiple eligible branches, we can still thread one of the ones that don't target a loop header. Patch by Keno Fischer! Differential Revision: https://reviews.llvm.org/D42260 llvm-svn: 328798
Diffstat (limited to 'llvm/tools/llvm-pdbutil/ExplainOutputStyle.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud