llvm-6502/lib/CodeGen
Anton Korobeynikov b10308e440 Propagate changes from my local tree. This patch includes:
1. New parameter attribute called 'inreg'. It has meaning "place this
parameter in registers, if possible". This is some generalization of
gcc's regparm(n) attribute. It's currently used only in X86-32 backend.
2. Completely rewritten CC handling/lowering code inside X86 backend.
Merged stdcall + c CCs and fastcall + fast CC.
3. Dropped CSRET CC. We cannot add struct return variant for each
target-specific CC (e.g. stdcall + csretcc and so on).
4. Instead of CSRET CC introduced 'sret' parameter attribute. Setting in
on first attribute has meaning 'This is hidden pointer to structure
return. Handle it gently'.
5. Fixed small bug in llvm-extract + add new feature to
FunctionExtraction pass, which relinks all internal-linkaged callees
from deleted function to external linkage. This will allow further
linking everything together.

NOTEs: 1. Documentation will be updated soon.
       2. llvm-upgrade should be improved to translate csret => sret.
          Before this, there will be some unexpected test fails.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33597 91177308-0d34-0410-b5e6-96231b3b80d8
2007-01-28 13:31:35 +00:00
..
SelectionDAG Propagate changes from my local tree. This patch includes: 2007-01-28 13:31:35 +00:00
AsmPrinter.cpp Change the MachineDebugInfo to MachineModuleInfo to better reflect usage 2007-01-26 21:22:28 +00:00
BranchFolding.cpp Change the MachineDebugInfo to MachineModuleInfo to better reflect usage 2007-01-26 21:22:28 +00:00
DwarfWriter.cpp Change the MachineDebugInfo to MachineModuleInfo to better reflect usage 2007-01-26 21:22:28 +00:00
ELFWriter.cpp Use TargetELFWriterInfo class. 2007-01-27 02:55:44 +00:00
IntrinsicLowering.cpp rename Type::isIntegral to Type::isInteger, eliminating the old Type::isInteger. 2007-01-15 02:27:26 +00:00
LiveInterval.cpp Added an automatic cast to "std::ostream*" etc. from OStream. We then can 2006-12-17 05:15:13 +00:00
LiveIntervalAnalysis.cpp Eliminate static ctors from Statistics 2006-12-19 22:41:21 +00:00
LiveVariables.cpp Removed more <iostream> includes 2006-12-07 20:28:15 +00:00
LLVMTargetMachine.cpp Removed more <iostream> includes 2006-12-07 20:28:15 +00:00
MachineBasicBlock.cpp The best unbreakage yet, addressing Bill's concerns. 2006-12-16 02:15:42 +00:00
MachineFunction.cpp Teach TargetData to handle 'preferred' alignment for each target, and use 2007-01-20 22:35:55 +00:00
MachineInstr.cpp The best unbreakage yet, addressing Bill's concerns. 2006-12-16 02:15:42 +00:00
MachineModuleInfo.cpp rename files 2007-01-26 21:38:26 +00:00
MachinePassRegistry.cpp Final polish on machine pass registries. 2006-08-02 12:30:23 +00:00
MachOWriter.cpp Handle multiple functions, properly mangle symbols, and fix support for 2007-01-26 22:39:48 +00:00
Makefile this will work better 2006-11-03 19:15:55 +00:00
Passes.cpp *** empty log message *** 2006-11-16 20:11:33 +00:00
PHIElimination.cpp Eliminate static ctors from Statistics 2006-12-19 22:41:21 +00:00
PhysRegTracker.h
PrologEpilogInserter.cpp Change the MachineDebugInfo to MachineModuleInfo to better reflect usage 2007-01-26 21:22:28 +00:00
RegAllocLinearScan.cpp Eliminate static ctors from Statistics 2006-12-19 22:41:21 +00:00
RegAllocLocal.cpp Eliminate static ctors from Statistics 2006-12-19 22:41:21 +00:00
RegAllocSimple.cpp Eliminate static ctors from Statistics 2006-12-19 22:41:21 +00:00
TwoAddressInstructionPass.cpp Eliminate static ctors from Statistics 2006-12-19 22:41:21 +00:00
UnreachableBlockElim.cpp eliminate RegisterOpt. It does the same thing as RegisterPass. 2006-08-27 22:42:52 +00:00
VirtRegMap.cpp Switch this to use SmallSet to avoid mallocs in the common case. 2007-01-23 00:59:48 +00:00
VirtRegMap.h Added an automatic cast to "std::ostream*" etc. from OStream. We then can 2006-12-17 05:15:13 +00:00