llvm-project/llvm
Max Kazantsev 34ae308c73 [SCEV] Use context to strengthen flags of BinOps
Sometimes SCEV cannot infer nuw/nsw from something as simple as
```
  len in [0, MAX_INT]
...
  iv = phi(0, iv.next)
  guard(iv <s len)
  guard(iv <u len)
  iv.next = iv + 1
```
just because flag strenthening only relies on definition and does not use local facts.
This patch adds support for the simplest case: inference of flags of `add(x, constant)`
if we can contextually prove that `x <= max_int - constant`.

In case if it has negative CT impact, we can add an option to switch it off. I woudln't
expect that though.

Differential Revision: https://reviews.llvm.org/D129643
Reviewed By: apilipenko
2022-08-03 14:08:57 +07:00
..
benchmarks
bindings [IR] Remove support for float binop constant expressions 2022-07-12 09:40:49 +02:00
cmake [cmake] Support native LoongArch builds 2022-08-01 15:10:24 +08:00
docs [LangRef] Fix typo in GEP docs 2022-08-02 09:30:17 +02:00
examples [Examples] Fix SimplifyCFG example 2022-08-01 07:22:35 +02:00
include [SCEV] Use context to strengthen flags of BinOps 2022-08-03 14:08:57 +07:00
lib [SCEV] Use context to strengthen flags of BinOps 2022-08-03 14:08:57 +07:00
projects
resources
runtimes
test [SCEV] Use context to strengthen flags of BinOps 2022-08-03 14:08:57 +07:00
tools avoid a bug where we remove a BB and then the next one becomes the 2022-08-02 22:23:12 -06:00
unittests [IRBuilder] Handle constexpr-bitcast for IRBuilder::CreateThreadLocalAddress 2022-08-03 11:13:49 +08:00
utils [gn build] Port 68264b6494 2022-08-03 05:46:25 +00:00
.clang-format
.clang-tidy
.gitattributes
.gitignore
CMakeLists.txt Bump the trunk major version to 16 2022-07-26 21:34:45 -07:00
CODE_OWNERS.TXT
CREDITS.TXT
LICENSE.TXT
README.txt
RELEASE_TESTERS.TXT
configure
llvm.spec.in

README.txt

The LLVM Compiler Infrastructure
================================

This directory and its subdirectories contain source code for LLVM,
a toolkit for the construction of highly optimized compilers,
optimizers, and runtime environments.

LLVM is open source software. You may freely distribute it under the terms of
the license agreement found in LICENSE.txt.

Please see the documentation provided in docs/ for further
assistance with LLVM, and in particular docs/GettingStarted.rst for getting
started with LLVM and docs/README.txt for an overview of LLVM's
documentation setup.

If you are writing a package for LLVM, see docs/Packaging.rst for our
suggestions.