llvm-6502/lib/Target
Duraid Madina b2322561cb * Add code to reduce multiplies by constant integers to shifts, adds and
subtracts. This is a very rough and nasty implementation of Lefevre's
  "pattern finding" algorithm. With a few small changes though, it should
  end up beating most other methods in common use, regardless of the size
  of the constant (currently, it's often one or two shifts worse)

  TODO: rewrite it so it's not hideously ugly (this is a translation from
        perl, which doesn't help ;)
        bypass most of it for multiplies by 2^n+1
	(eventually) teach it that some combinations of shift+add are
	cheaper than others (e.g. shladd on ia64, scaled adds on alpha)
	get it to try multiple booth encodings in search of the cheapest
	routine
	make it work for negative constants

  This is hacked up as a DAG->DAG transform, so once I clean it up I hope
  it'll be pulled out of here and put somewhere else. The only thing backends
  should really have to worry about for now is where to draw the line
  between using this code vs. going ahead and doing an integer multiply
  anyway.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@21560 91177308-0d34-0410-b5e6-96231b3b80d8
2005-04-26 07:23:02 +00:00
..
Alpha Convert tabs to spaces 2005-04-22 17:54:37 +00:00
CBackend
IA64 * Add code to reduce multiplies by constant integers to shifts, adds and 2005-04-26 07:23:02 +00:00
PowerPC Convert tabs to spaces 2005-04-22 17:54:37 +00:00
Skeleton Convert tabs to spaces 2005-04-22 17:54:37 +00:00
Sparc Convert tabs to spaces 2005-04-22 18:06:01 +00:00
SparcV8 Convert tabs to spaces 2005-04-22 18:06:01 +00:00
SparcV9 Updated dependence analyzer. Fixed numerous bugs. Same stage scheduling, etc. 2005-04-22 06:32:48 +00:00
X86 * Remove trailing whitespace 2005-04-21 23:38:14 +00:00
Makefile Implement the --enable-targets= feature of the configure script. The make 2005-04-22 17:20:11 +00:00
MRegisterInfo.cpp Convert tabs to spaces 2005-04-22 17:54:37 +00:00
Target.td
TargetData.cpp
TargetFrameInfo.cpp Shut GCC 4.0 up about classes that have virtual functions but a non-virtual 2005-04-25 02:55:55 +00:00
TargetInstrInfo.cpp Convert tabs to spaces 2005-04-22 17:54:37 +00:00
TargetMachine.cpp
TargetMachineRegistry.cpp
TargetSchedInfo.cpp Convert tabs to spaces 2005-04-22 17:54:37 +00:00