LLVM backend for 6502
Go to file
Tom Stellard b80f06729a Merging r205738:
------------------------------------------------------------------------
r205738 | atrick | 2014-04-07 17:29:22 -0400 (Mon, 07 Apr 2014) | 16 lines

Put a limit on ScheduleDAGSDNodes::ClusterNeighboringLoads to avoid blowing up compile time.

Fixes PR16365 - Extremely slow compilation in -O1 and -O2.

The SD scheduler has a quadratic implementation of load clustering
which absolutely blows up compile time for large blocks with constant
pool loads. The MI scheduler has a better implementation of load
clustering. However, we have not done the work yet to completely
eliminate the SD scheduler. Some benchmarks still seem to benefit from
early load clustering, although maybe by chance.

As an intermediate term fix, I just put a nice limit on the number of
DAG users to search before finding a match. With this limit there are no
binary differences in the LLVM test suite, and the PR16365 test case
does not suffer any compile time impact from this routine.

------------------------------------------------------------------------

git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_34@205808 91177308-0d34-0410-b5e6-96231b3b80d8
2014-04-08 21:47:17 +00:00
autoconf Bump version to 3.4.1 2014-03-19 21:40:45 +00:00
bindings Merging r195912: 2013-12-02 19:18:50 +00:00
cmake Revert my CMake patches concerning building with /MT (r194589, r194596) 2013-11-13 20:29:10 +00:00
docs Small reformatting changes. 2013-12-24 06:29:42 +00:00
examples Merging r195092: 2013-11-19 06:35:35 +00:00
include Merging r198744: 2014-04-08 14:28:03 +00:00
lib Merging r205738: 2014-04-08 21:47:17 +00:00
projects Revert "Revert "Windows: Add support for unicode command lines"" 2013-10-07 01:00:07 +00:00
test Merging r200202: 2014-04-08 21:47:15 +00:00
tools Merging r202720: 2014-03-19 20:36:02 +00:00
unittests Merging r197718: 2013-12-20 04:26:57 +00:00
utils Merging r195567: 2013-11-24 05:30:06 +00:00
.arcconfig
.clang-format
.gitignore
CMakeLists.txt Bump version to 3.4.1 2014-03-19 21:40:45 +00:00
CODE_OWNERS.TXT Merging r196369: 2013-12-07 09:35:00 +00:00
configure Bump version to 3.4.1 2014-03-19 21:40:45 +00:00
CREDITS.TXT Update CREDITS 2013-11-17 11:44:36 +00:00
LICENSE.TXT
llvm.spec.in
LLVMBuild.txt
Makefile
Makefile.common
Makefile.config.in Merging r202720: 2014-03-19 20:36:02 +00:00
Makefile.rules Merging r202720: 2014-03-19 20:36:02 +00:00
README.txt Revert "Test commit to check e-mail address. Please discard this." 2013-10-04 10:59:13 +00:00

Low Level Virtual Machine (LLVM)
================================

This directory and its subdirectories contain source code for the Low Level
Virtual Machine, 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're writing a package for LLVM, see docs/Packaging.rst for our
suggestions.