aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Tooling/Syntax/BuildTree.cpp
diff options
context:
space:
mode:
authorMax Kazantsev <mkazantsev@azul.com>2021-02-11 11:57:23 +0700
committerMax Kazantsev <mkazantsev@azul.com>2021-02-11 11:59:45 +0700
commit3d15b7e7dfc3e2cefc47791d1e8d95909e937842 (patch)
tree912cfb7987a2ffdb719604f38e718fce98a7d3bb /clang/lib/Tooling/Syntax/BuildTree.cpp
parent6efcc2fd3f138160a710f3c152ee1c54c2e50420 (diff)
downloadllvm-3d15b7e7dfc3e2cefc47791d1e8d95909e937842.zip
llvm-3d15b7e7dfc3e2cefc47791d1e8d95909e937842.tar.gz
llvm-3d15b7e7dfc3e2cefc47791d1e8d95909e937842.tar.bz2
[Codegenprepare][X86] Use usub with overflow opt for IV increment
Function `replaceMathCmpWithIntrinsic` artificially limits the scope of the optimization, setting a requirement of two instructions be in the same block, due to two reasons: - usage of DT for more general check is costly in terms of compile time; - risk of creating a new value that lives through multiple blocks. Because of this, two semantically equivalent tests may be or not be the subject of this opt depending on where the binary operation is located. See `test/CodeGen/X86/usub_inc_iv.ll` for motivation There is one important particular case where this limitation is too strict: it is when the binary operation is the increment of the induction variable. As result, the application of this opt becomes fragile and highly reliant on where other passes decide to place IV increment. In most cases, they place it in the end of the latch block, killing the opt opportunity (when in fact it does not matter where to insert the actual instruction). This patch handles this particular case separately. - The detector does not use dom tree and has constant cost; - The value of IV or IV.next lives through all loop in any case, so this should not create a new unexpected long-living value. As result, the transform becomes more robust. It also seems to lead to better code generation in some cases (see `test/CodeGen/X86/lsr-loop-exit-cond.ll`). Differential Revision: https://reviews.llvm.org/D96119 Reviewed By: spatel, reames
Diffstat (limited to 'clang/lib/Tooling/Syntax/BuildTree.cpp')
0 files changed, 0 insertions, 0 deletions