|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| ... |  | 
| | 
| 
| 
| 
| 
| | out of TargetRegisterInfo to TargetFrameInfo, which is definitely much better suitable place
llvm-svn: 119097 | 
| | 
| 
| 
| 
| 
| 
| 
| | Move EmitTargetCodeForMemcpy, EmitTargetCodeForMemset, and
EmitTargetCodeForMemmove out of TargetLowering and into
SelectionDAGInfo to exercise this.
llvm-svn: 103481 | 
| | 
| 
| 
| 
| 
| | 64-bit sparc codegen.  Patch by Nathan Keynes!
llvm-svn: 95293 | 
| | 
| 
| 
| 
| 
| | Please verify.
llvm-svn: 86397 | 
| | 
| 
| 
| | llvm-svn: 79763 | 
| | 
| 
| 
| 
| 
| 
| 
| | pair instead of from a virtual method on TargetMachine.  This cuts the final
ties of TargetAsmInfo to TargetMachine, meaning that MC can now use 
TargetAsmInfo.
llvm-svn: 78802 | 
| | 
| 
| 
| 
| 
| | LLVMTargetMachine ctor.  It is currently unused.
llvm-svn: 78711 | 
| | 
| 
| 
| 
| 
| | - The C, C++, MSIL, and Mips backends still need the module.
llvm-svn: 77927 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Module*.
Also, dropped uses of TargetMachine where unnecessary. The only target which
still takes a TargetMachine& is Mips, I would appreciate it if someone would
normalize this to match other targets.
llvm-svn: 77918 | 
| | 
| 
| 
| | llvm-svn: 77864 | 
| | 
| 
| 
| 
| 
| | - Less boilerplate == good.
llvm-svn: 77052 | 
| | 
| 
| 
| | llvm-svn: 76344 | 
| | 
| 
| 
| 
| 
| | - No functionality change.
llvm-svn: 75859 | 
| | 
| 
| 
| 
| 
| | - No intended functionality change.
llvm-svn: 75843 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | --- Reverse-merging r75799 into '.':
 U   test/Analysis/PointerTracking
U    include/llvm/Target/TargetMachineRegistry.h
U    include/llvm/Target/TargetMachine.h
U    include/llvm/Target/TargetRegistry.h
U    include/llvm/Target/TargetSelect.h
U    tools/lto/LTOCodeGenerator.cpp
U    tools/lto/LTOModule.cpp
U    tools/llc/llc.cpp
U    lib/Target/PowerPC/PPCTargetMachine.h
U    lib/Target/PowerPC/AsmPrinter/PPCAsmPrinter.cpp
U    lib/Target/PowerPC/PPCTargetMachine.cpp
U    lib/Target/PowerPC/PPC.h
U    lib/Target/ARM/ARMTargetMachine.cpp
U    lib/Target/ARM/AsmPrinter/ARMAsmPrinter.cpp
U    lib/Target/ARM/ARMTargetMachine.h
U    lib/Target/ARM/ARM.h
U    lib/Target/XCore/XCoreTargetMachine.cpp
U    lib/Target/XCore/XCoreTargetMachine.h
U    lib/Target/PIC16/PIC16TargetMachine.cpp
U    lib/Target/PIC16/PIC16TargetMachine.h
U    lib/Target/Alpha/AsmPrinter/AlphaAsmPrinter.cpp
U    lib/Target/Alpha/AlphaTargetMachine.cpp
U    lib/Target/Alpha/AlphaTargetMachine.h
U    lib/Target/X86/X86TargetMachine.h
U    lib/Target/X86/X86.h
U    lib/Target/X86/AsmPrinter/X86ATTAsmPrinter.h
U    lib/Target/X86/AsmPrinter/X86AsmPrinter.cpp
U    lib/Target/X86/AsmPrinter/X86IntelAsmPrinter.h
U    lib/Target/X86/X86TargetMachine.cpp
U    lib/Target/MSP430/MSP430TargetMachine.cpp
U    lib/Target/MSP430/MSP430TargetMachine.h
U    lib/Target/CppBackend/CPPTargetMachine.h
U    lib/Target/CppBackend/CPPBackend.cpp
U    lib/Target/CBackend/CTargetMachine.h
U    lib/Target/CBackend/CBackend.cpp
U    lib/Target/TargetMachine.cpp
U    lib/Target/IA64/IA64TargetMachine.cpp
U    lib/Target/IA64/AsmPrinter/IA64AsmPrinter.cpp
U    lib/Target/IA64/IA64TargetMachine.h
U    lib/Target/IA64/IA64.h
U    lib/Target/MSIL/MSILWriter.cpp
U    lib/Target/CellSPU/SPUTargetMachine.h
U    lib/Target/CellSPU/SPU.h
U    lib/Target/CellSPU/AsmPrinter/SPUAsmPrinter.cpp
U    lib/Target/CellSPU/SPUTargetMachine.cpp
U    lib/Target/Mips/AsmPrinter/MipsAsmPrinter.cpp
U    lib/Target/Mips/MipsTargetMachine.cpp
U    lib/Target/Mips/MipsTargetMachine.h
U    lib/Target/Mips/Mips.h
U    lib/Target/Sparc/AsmPrinter/SparcAsmPrinter.cpp
U    lib/Target/Sparc/SparcTargetMachine.cpp
U    lib/Target/Sparc/SparcTargetMachine.h
U    lib/ExecutionEngine/JIT/TargetSelect.cpp
U    lib/Support/TargetRegistry.cpp
llvm-svn: 75820 | 
| | 
| 
| 
| 
| 
| 
| 
| | repair broken LLVM-GCC build.
Will revert 75770 in the llvm-gcc trunk.
llvm-svn: 75799 | 
| | 
| 
| 
| | llvm-svn: 75780 | 
| | 
| 
| 
| 
| 
| 
| 
| | from.
 - This commit is almost entirely propogating the reference through the
   TargetMachine subclasses' constructor calls.
llvm-svn: 75778 | 
| | 
| 
| 
| 
| 
| 
| | - This abuses TargetMachineRegistry's constructor for now, this will get
   cleaned up in time.
llvm-svn: 75762 | 
| | 
| 
| 
| 
| 
| | dynamic_cast<>.
llvm-svn: 75670 | 
| | 
| 
| 
| 
| 
| 
| | - This more or less amounts to a revert of r65379. I'm curious to know what
   happened that caused this variable to become unused.
llvm-svn: 74579 | 
| | 
| 
| 
| 
| 
| 
| 
| | C bindings.  Change all the backend "Initialize" functions to have C linkage.
Change the "llvm/Config/Targets.def" header to use C-style comments to avoid
compile warnings.
llvm-svn: 74026 | 
| | 
| 
| 
| | llvm-svn: 73767 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | initialization of all targets (InitializeAllTargets.h) or assembler
printers (InitializeAllAsmPrinters.h). This is a step toward the
elimination of relinked object files, so that we can build normal
archives.
llvm-svn: 73543 | 
| | 
| 
| 
| 
| 
| 
| | which better identifies what the optimization is doing. And is more flexible for
future uses.
llvm-svn: 70440 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Massive check in. This changes the "-fast" flag to "-O#" in llc. If you want to
use the old behavior, the flag is -O0. This change allows for finer-grained
control over which optimizations are run at different -O levels.
Most of this work was pretty mechanical. The majority of the fixes came from
verifying that a "fast" variable wasn't used anymore. The JIT still uses a
"Fast" flag. I'll change the JIT with a follow-up patch.
llvm-svn: 70343 | 
| | 
| 
| 
| | llvm-svn: 70275 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | use the old behavior, the flag is -O0. This change allows for finer-grained
control over which optimizations are run at different -O levels.
Most of this work was pretty mechanical. The majority of the fixes came from
verifying that a "fast" variable wasn't used anymore. The JIT still uses a
"Fast" flag. I'm not 100% sure if it's necessary to change it there...
llvm-svn: 70270 | 
| | 
| 
| 
| 
| 
| | default to verbose.
llvm-svn: 67668 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | them are generic changes.
- Use the "fast" flag that's already being passed into the asm printers instead
  of shoving it into the DwarfWriter.
- Instead of calling "MI->getParent()->getParent()" for every MI, set the
  machine function when calling "runOnMachineFunction" in the asm printers.
llvm-svn: 65379 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | well as 2 files that use "Registrator"s. These are to be used by the
MSVC builds, as the Win32 linker does not include libs that are
otherwise unreferenced, even if global constructors in the lib have
side-effects.
Patch by Scott Graham!
llvm-svn: 59378 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| | instead of requiring all "short description" strings to begin with
two spaces. This makes these strings less mysterious, and it fixes
some cases where short description strings mistakenly did not
begin with two spaces.
llvm-svn: 57521 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | Instead, just create one, and make sure everything that needs
it can access it. Previously most of the SelectionDAGISel
subclasses all had their own TargetLowering object, which was
redundant with the TargetLowering object in the TargetMachine
subclasses, except on Sparc, where SparcTargetMachine
didn't have a TargetLowering object. Change Sparc to work
more like the other targets here.
llvm-svn: 57016 | 
| | 
| 
| 
| | llvm-svn: 55092 | 
| | 
| 
| 
| 
| 
| | module-level GVs significantly.
llvm-svn: 54450 | 
| | 
| 
| 
| 
| 
| 
| | several things that were neither in an anonymous namespace nor static
but not intended to be global.
llvm-svn: 51017 | 
| | 
| 
| 
| 
| 
| 
| 
| | that merely add passes. This allows them to be used with either
FunctionPassManager or PassManager, or even with a custom new
kind of pass manager.
llvm-svn: 48256 | 
| | 
| 
| 
| | llvm-svn: 45418 | 
| | 
| 
| 
| 
| 
| 
| | (I've tried to get the info right for all targets,
but I'm not expert on all of them - check yours.)
llvm-svn: 40792 | 
| | 
| 
| 
| 
| 
| | the sparc backend should be preferred when running on sparcs.
llvm-svn: 39142 | 
| | 
| 
| 
| 
| 
| | zero if they see a target triple they don't understand.
llvm-svn: 38463 | 
| | 
| 
| 
| | llvm-svn: 32333 | 
| | 
| 
| 
| 
| 
| 
| 
| | 2. Protect and outline createTargetAsmInfo.
3. Misc. kruft.
llvm-svn: 30169 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | This pass:
1. Splits TargetMachine into TargetMachine (generic targets, can be implemented
any way, like the CBE) and LLVMTargetMachine (subclass of TM that is used by
things using libcodegen and other support).
2. Instead of having each target fully populate the passmgr for file or JIT
   output, move all this to common code, and give targets hooks they can
   implement.
3. Commonalize the target population stuff between file emission and JIT
   emission.
4. All (native code) codegen stuff now happens in a FunctionPassManager, which
   paves the way for "fast -O0" stuff in the CFE later, and now LLC could
   lazily stream .bc files from disk to use less memory.
5. There are now many fewer #includes and the targets don't depend on the
   scalar xforms or libanalysis anymore (but codegen does).
6. Changing common code generator pass ordering stuff no longer requires
   touching all targets.
7. The JIT now has the option of "-fast" codegen or normal optimized codegen,
   which is now orthogonal to the fact that JIT'ing is being done.
llvm-svn: 30081 | 
| | 
| 
| 
| | llvm-svn: 30070 | 
| | 
| 
| 
| 
| 
| 
| | Remove explicit casts to std::string now that there is no overload resolution
issues in the TargetData ctors.
llvm-svn: 28830 | 
| | 
| 
| 
| | llvm-svn: 28415 | 
| | 
| 
| 
| 
| 
| | This is part of the on-going work on PR 761.
llvm-svn: 28414 | 
| | 
| 
| 
| 
| 
| 
| 
| | target-specific subclasses.  This has one caller-visible change: getTargetData() now returns a pointer instead of a reference.
This fixes PR 759.
llvm-svn: 28074 | 
| | 
| 
| 
| 
| 
| | letting the code generator handle them directly.
llvm-svn: 27539 |