|  | Commit message (Collapse) | Author | Age | Files | Lines | 
|---|
| | 
| 
| 
| 
| 
| | This reverts commit r283017. Creates an infinite loop somehow.
llvm-svn: 283019 | 
| | 
| 
| 
| | llvm-svn: 283017 | 
| | 
| 
| 
| 
| 
| | No functionality change is intended.
llvm-svn: 278443 | 
| | 
| 
| 
| 
| 
| 
| 
| | The program using this code may not have it.
Patch by Wilfred Hughes.
llvm-svn: 259106 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The TargetRegistry is just a namespace-like class, instantiated in one
place to use a range-based for loop. Instead, expose access to the
registry via a range-based 'targets()' function instead. This makes most
uses a bit awkward/more verbose - but eventually we should just add a
range-based find_if function which will streamline these functions. I'm
happy to mkae them a bit awkward in the interim as encouragement to
improve the algorithms in time.
llvm-svn: 237059 | 
| | 
| 
| 
| 
| 
| | NFC.
llvm-svn: 232976 | 
| | 
| 
| 
| 
| 
| 
| | This was kept around "for compatibility through 2.6" in 2009 and is not used or
tested.
llvm-svn: 212095 | 
| | 
| 
| 
| 
| 
| | to reduce verbosity.
llvm-svn: 205829 | 
| | 
| 
| 
| | llvm-svn: 205697 | 
| | 
| 
| 
| 
| 
| | Looks like GCC implements the lambda->function pointer conversion differently.
llvm-svn: 203294 | 
| | 
| 
| 
| 
| 
| | No functionality change.
llvm-svn: 203288 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | The cpp backend is not a reasonable fallback for a missing target. It is a
very special backend, so it is reasonable to use it only if explicitly
requested.
While at it, simplify the interface a bit.
llvm-svn: 197241 | 
| | 
| 
| 
| 
| 
| 
| 
| | This makes using array_pod_sort significantly safer. The implementation relies
on function pointer casting but that should be safe as we're dealing with void*
here.
llvm-svn: 191175 | 
| | 
| 
| 
| 
| 
| | PR12731.  Patch by Meador Inge!
llvm-svn: 156444 | 
| | 
| 
| 
| | llvm-svn: 147608 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | Get back getHostTriple.
For JIT compilation, use the host triple instead of the default
target: this fixes some JIT testcases that used to fail when the
compiler has been configured as a cross compiler.
llvm-svn: 147542 | 
| | 
| 
| 
| | llvm-svn: 143502 | 
| | 
| 
| 
| 
| 
| | These are strictly utilities for registering targets and components.
llvm-svn: 138450 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | The header file was already properly located. The previous need for it
in Support had to do with the version string printing which was fixed in
r135757.
Also update build dependencies where libraries that needed the
functionality of the Target library (in the form of the TargetRegistry)
were picking it up via Support. This is pretty pervasive, essentially
every TargetInfo library (ARMInfo, etc) uses TargetRegistry, making it
depend on Target. All of these were previously just sneaking by.
llvm-svn: 135760 | 
| | 
| 
| 
| 
| 
| 
| | function on the TargetRegistry. Also clean it up and use the modern LLVM
utility libraries available instead of rolling a few things manually.
llvm-svn: 135756 | 
| | 
| 
| 
| | llvm-svn: 120298 | 
| | 
| 
| 
| 
| 
| | mention -version in messages about missing targets.
llvm-svn: 81272 | 
| | 
| 
| 
| | llvm-svn: 77950 | 
| | 
| 
| 
| | llvm-svn: 77115 | 
| | 
| 
| 
| 
| 
| | - This was overkill and inconsistently implemented.
llvm-svn: 77114 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | - This is a simplified mechanism which just looks up a target based on the
   target triple, with a few additional flags.
 - Remove getClosestStaticTargetForModule, the moral equivalent is now:
     lookupTarget(Mod->getTargetTriple, true, false, ...);
 - This no longer does the fuzzy matching with target data (based on endianness
   and pointer width) that getClosestStaticTargetForModule was doing, but this
   was deemed unnecessary.
llvm-svn: 77111 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| | - Instead of requiring targets to define a JIT quality match function, we just
   have them specify if they support a JIT.
 - Target selection for the JIT just gets the host triple and looks for the best
   target which matches the triple and has a JIT.
llvm-svn: 77060 | 
| | 
| 
| 
| 
| 
| | none are registered.
llvm-svn: 76181 | 
| | 
| 
| 
| | llvm-svn: 75889 | 
| | 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| 
| | --- 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 | 
| | 
| 
| 
| 
| 
| 
| | - This doesn't necessarily seem like a good idea, but the JIT unittest
   currently relies on it.
llvm-svn: 75769 | 
| | 
| 
| 
| | llvm-svn: 75754 | 
| | 
| 
| 
| | llvm-svn: 75753 | 
|  | Targets implement a single global Target structure which will live in a new
<Target>/TargetInfo library; this will be present in any image which the target
is usable in.
 - Optional target specific classes can then be registered and attached to the
   Target description.
 - Registration for normal Targets will be done via the initialization functions
   instead of using static constructors.
 - This allows clients to use a single interface to obtain target data, without
   requiring the code generator be linked in. It also provides a natural
   extension point for adding new optional target data (assembler parser,
   disassembler, etc.).
 - This also provides a new entry point for obtaining a target for a particular
   triple (without a module).
 - Not yet used, however this should eventually replace the TargetMachineRegistry.
llvm-svn: 75739 |