LLVM backend for 6502
Go to file
Chandler Carruth d862d697d2 Finish fixing the MachineOperand hashing, providing a nice modern
hash_value overload for MachineOperands. This addresses a FIXME
sufficient for me to remove it, and cleans up the code nicely too.

The important changes to the hashing logic:
- TargetFlags are now included in all of the hashes. These were complete
  missed.
- Register operands have their subregisters and whether they are a def
  included in the hash.
- We now actually hash all of the operand types. Previously, many
  operand types were simply *dropped on the floor*. For example:
  - Floating point immediates
  - Large integer immediates (>64-bit)
  - External globals!
  - Register masks
  - Metadata operands
- It removes the offset from the block-address hash; I'm a bit
  suspicious of this, but isIdenticalTo doesn't consider the offset for
  black addresses.

Any patterns involving these entities could have triggered extreme
slowdowns in MachineCSE or PHIElimination. Let me know if there are PRs
you think might be closed now... I'm looking myself, but I may miss
them.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@159743 91177308-0d34-0410-b5e6-96231b3b80d8
2012-07-05 11:06:22 +00:00
autoconf
bindings
cmake Revert r159588, and apply a more principled fix. Place the fix for this 2012-07-02 21:31:03 +00:00
docs Document the llvm.fabs intrinsic. 2012-07-03 12:25:40 +00:00
examples Move llvm/Support/IRBuilder.h -> llvm/IRBuilder.h 2012-06-29 12:38:19 +00:00
include Finish fixing the MachineOperand hashing, providing a nice modern 2012-07-05 11:06:22 +00:00
lib Finish fixing the MachineOperand hashing, providing a nice modern 2012-07-05 11:06:22 +00:00
projects
runtime
test Use the right kind of booleans: we were emitting 0/1 booleans, instead of 0/-1 2012-07-05 09:32:46 +00:00
tools Target option DisableJumpTables is a gross hack. Move it to TargetLowering instead. 2012-07-02 22:39:56 +00:00
unittests Revert "IntRange:" as it appears to be breaking self hosting. 2012-07-02 23:22:21 +00:00
utils Revert r159528 which taught lit's builtin shell test runner about the 2012-07-02 20:43:21 +00:00
.gitignore
CMakeLists.txt Hoist LLVM's lit testsuite infrastructure into module so that it can be 2012-06-30 10:14:14 +00:00
configure Regenerate. 2012-06-28 20:35:00 +00:00
CREDITS.TXT
LICENSE.TXT
llvm.spec.in
LLVMBuild.txt
Makefile
Makefile.common
Makefile.config.in
Makefile.rules
README.txt

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 HTML documentation provided in docs/index.html for further
assistance with LLVM.

If you're writing a package for LLVM, see docs/Packaging.html for our
suggestions.