llvm-6502/lib/Target/R600
Michel Danzer d787c047bc R600/SI: Use source scheduler
This is certainly not the last word on scheduling for this target, but
right now this allows a few apps to run / finish with radeonsi, most
notably UT2004 / Lightsmark. They fail to compile some shaders with the
default scheduler because it ends up trying to spill registers, which
we don't support yet (and which is probably a bad idea in general for
performance if it can be avoided).

NOTE: This is a candidate for the Mesa stable branch.

Reviewed-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Tom Stellard <thomas.stellard@amd.com>

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@176687 91177308-0d34-0410-b5e6-96231b3b80d8
2013-03-08 10:58:01 +00:00
..
InstPrinter R600/SI: add all the other missing asm operands v2 2013-02-21 15:17:22 +00:00
MCTargetDesc R600/SI: remove GPR*AlignEncode 2013-03-01 09:46:17 +00:00
TargetInfo
AMDGPU.h R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
AMDGPU.td R600/SI: add proper formal parameter handling for SI 2013-03-07 09:03:52 +00:00
AMDGPUAsmPrinter.cpp R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
AMDGPUAsmPrinter.h
AMDGPUCallingConv.td R600/SI: add proper formal parameter handling for SI 2013-03-07 09:03:52 +00:00
AMDGPUConvertToISA.cpp Add R600 backend 2012-12-11 21:25:42 +00:00
AMDGPUFrameLowering.cpp
AMDGPUFrameLowering.h
AMDGPUIndirectAddressing.cpp R600/SI: fix unused variable warning 2013-03-07 09:03:30 +00:00
AMDGPUInstrInfo.cpp R600/SI: add VOP mapping functions 2013-02-26 17:52:42 +00:00
AMDGPUInstrInfo.h
AMDGPUInstrInfo.td
AMDGPUInstructions.td R600/SI: remove shader type intrinsic 2013-03-07 09:03:46 +00:00
AMDGPUIntrinsics.td R600/SI: remove shader type intrinsic 2013-03-07 09:03:46 +00:00
AMDGPUISelLowering.cpp R600/SI: add proper formal parameter handling for SI 2013-03-07 09:03:52 +00:00
AMDGPUISelLowering.h R600/SI: add proper formal parameter handling for SI 2013-03-07 09:03:52 +00:00
AMDGPUMCInstLower.cpp
AMDGPUMCInstLower.h
AMDGPURegisterInfo.cpp
AMDGPURegisterInfo.h
AMDGPURegisterInfo.td
AMDGPUStructurizeCFG.cpp R600/SI: fix warning about overloaded virtual 2013-03-01 09:46:11 +00:00
AMDGPUSubtarget.cpp
AMDGPUSubtarget.h
AMDGPUTargetMachine.cpp R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
AMDGPUTargetMachine.h
AMDIL7XXDevice.cpp
AMDIL7XXDevice.h
AMDIL.h R600/SI: remove SGPR address space v2 2013-03-07 09:03:59 +00:00
AMDILBase.td
AMDILCFGStructurizer.cpp
AMDILDevice.cpp R600: Clean up datalayout strings so they better match hardware capabilities 2013-03-04 17:40:28 +00:00
AMDILDevice.h
AMDILDeviceInfo.cpp
AMDILDeviceInfo.h
AMDILDevices.h
AMDILEvergreenDevice.cpp
AMDILEvergreenDevice.h
AMDILInstrInfo.td R600/SI: Use MULADD_IEEE/V_MAD_F32 instruction for mad pattern 2013-02-18 14:11:28 +00:00
AMDILIntrinsicInfo.cpp
AMDILIntrinsicInfo.h
AMDILIntrinsics.td R600/SI: Use MULADD_IEEE/V_MAD_F32 instruction for mad pattern 2013-02-18 14:11:28 +00:00
AMDILISelDAGToDAG.cpp R600: Turn BUILD_VECTOR into Reg_Sequence 2013-03-05 15:04:49 +00:00
AMDILISelLowering.cpp R600/SI: add proper formal parameter handling for SI 2013-03-07 09:03:52 +00:00
AMDILNIDevice.cpp
AMDILNIDevice.h
AMDILPeepholeOptimizer.cpp
AMDILRegisterInfo.td
AMDILSIDevice.cpp R600: Clean up datalayout strings so they better match hardware capabilities 2013-03-04 17:40:28 +00:00
AMDILSIDevice.h
CMakeLists.txt R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
LLVMBuild.txt
Makefile
Processors.td
R600Defines.h
R600ExpandSpecialInstrs.cpp
R600InstrInfo.cpp R600: Do not predicate vector op 2013-03-05 19:12:06 +00:00
R600InstrInfo.h
R600Instructions.td R600: Remove LowerConstCopyPass and lower CONST_COPY right after ISel. 2013-03-05 15:04:55 +00:00
R600Intrinsics.td R600: Support for TBO 2013-02-18 14:11:19 +00:00
R600ISelLowering.cpp R600/SI: remove SGPR address space v2 2013-03-07 09:03:59 +00:00
R600ISelLowering.h
R600MachineFunctionInfo.cpp
R600MachineFunctionInfo.h
R600MachineScheduler.cpp R600: initial scheduler code 2013-03-05 18:41:32 +00:00
R600MachineScheduler.h R600: initial scheduler code 2013-03-05 18:41:32 +00:00
R600RegisterInfo.cpp R600: Mark all members of the TRegMem register class as reserved 2013-02-19 15:22:45 +00:00
R600RegisterInfo.h
R600RegisterInfo.td R600: Add AR_X to the R600_TReg_X register class. 2013-02-19 15:22:47 +00:00
R600Schedule.td
SIAnnotateControlFlow.cpp R600/SI: Check for empty stack in SIAnnotateControlFlow::isTopOfStack 2013-02-14 08:00:33 +00:00
SIInsertWaits.cpp R600/SI: fix inserting waits for unordered defines 2013-03-01 09:46:04 +00:00
SIInstrFormats.td R600/SI: remove GPR*AlignEncode 2013-03-01 09:46:17 +00:00
SIInstrInfo.cpp R600/SI: handle all registers in copyPhysReg v2 2013-03-01 09:46:27 +00:00
SIInstrInfo.h R600/SI: add VOP mapping functions 2013-02-26 17:52:42 +00:00
SIInstrInfo.td R600/SI: remove GPR*AlignEncode 2013-03-01 09:46:17 +00:00
SIInstructions.td R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
SIIntrinsics.td R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
SIISelLowering.cpp R600/SI: Use source scheduler 2013-03-08 10:58:01 +00:00
SIISelLowering.h R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
SILowerControlFlow.cpp R600/SI: cleanup literal handling v3 2013-02-16 11:28:22 +00:00
SIMachineFunctionInfo.cpp R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
SIMachineFunctionInfo.h R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
SIRegisterInfo.cpp
SIRegisterInfo.h
SIRegisterInfo.td R600/SI: rework input interpolation v2 2013-03-07 09:04:14 +00:00
SISchedule.td