llvm-project/llvm
Jonas Paulsson c56ffed304 [SystemZ] Bugfix in isFusableLoadOpStorePattern()
This function is responsible for checking the legality of fusing an instance
of load -> op -> store into a single operation. In the SystemZ backend the
check was incomplete and a test case emerged with a cycle in the instruction
selection DAG as a result.

Instead of using the NodeIds to determine node relationships,
hasPredecessorHelper() now is used just like in the X86 backend. This handled
the failing tests and as well gave a few additional transformations on
benchmarks.

The SystemZ isFusableLoadOpStorePattern() is now a very near copy of the X86
function, and it seems this could be made a utility function in common code
instead.

Review: Ulrich Weigand
https://reviews.llvm.org/D60255

llvm-svn: 357688
2019-04-04 12:12:35 +00:00
..
benchmarks
bindings
cmake [cmake] Add function for building native tool 2019-04-02 15:58:03 +00:00
docs AMDGPU: Remove dx10-clamp from subtarget features 2019-03-29 19:14:54 +00:00
examples
include Revert rL357655 and rL357656 from llvm/trunk: 2019-04-04 11:12:30 +00:00
lib [SystemZ] Bugfix in isFusableLoadOpStorePattern() 2019-04-04 12:12:35 +00:00
projects
resources
runtimes [runtime] Use --strip-all rather than --strip-sections 2019-03-10 04:26:54 +00:00
test [SystemZ] Bugfix in isFusableLoadOpStorePattern() 2019-04-04 12:12:35 +00:00
tools [llvm-symbolizer] Allow more flexible usage of -e. 2019-04-04 08:45:06 +00:00
unittests [codeview] Remove Type member from CVRecord 2019-04-04 00:28:48 +00:00
utils gn build: Merge r357663 2019-04-04 02:08:10 +00:00
.arcconfig
.clang-format
.clang-tidy
.gitattributes
.gitignore
CMakeLists.txt Moved everything SMT-related to LLVM and updated the cmake scripts. 2019-03-25 17:47:45 +00:00
CODE_OWNERS.TXT
CREDITS.TXT
LICENSE.TXT
LLVMBuild.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.