mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
6b7d99d473
This patch replaces the control flow handling with a new pass which structurize the graph before transforming it to machine instruction. This has a couple of different advantages and currently fixes 20 piglit tests without a single regression. It is now a general purpose transformation that could be not only be used for SI/R6xx, but also for other hardware implementations that use a form of structurized control flow. v2: further cleanup, fixes and documentation Patch by: Christian König Signed-off-by: Christian König <deathsimple@vodafone.de> Reviewed-by: Tom Stellard <thomas.stellard@amd.com> Tested-by: Michel Dänzer <michel.daenzer@amd.com> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@170591 91177308-0d34-0410-b5e6-96231b3b80d8
56 lines
1.6 KiB
CMake
56 lines
1.6 KiB
CMake
set(LLVM_TARGET_DEFINITIONS AMDGPU.td)
|
|
|
|
tablegen(LLVM AMDGPUGenRegisterInfo.inc -gen-register-info)
|
|
tablegen(LLVM AMDGPUGenInstrInfo.inc -gen-instr-info)
|
|
tablegen(LLVM AMDGPUGenDAGISel.inc -gen-dag-isel)
|
|
tablegen(LLVM AMDGPUGenCallingConv.inc -gen-callingconv)
|
|
tablegen(LLVM AMDGPUGenSubtargetInfo.inc -gen-subtarget)
|
|
tablegen(LLVM AMDGPUGenIntrinsics.inc -gen-tgt-intrinsic)
|
|
tablegen(LLVM AMDGPUGenMCCodeEmitter.inc -gen-emitter -mc-emitter)
|
|
tablegen(LLVM AMDGPUGenDFAPacketizer.inc -gen-dfa-packetizer)
|
|
tablegen(LLVM AMDGPUGenAsmWriter.inc -gen-asm-writer)
|
|
add_public_tablegen_target(AMDGPUCommonTableGen)
|
|
|
|
add_llvm_target(R600CodeGen
|
|
AMDIL7XXDevice.cpp
|
|
AMDILCFGStructurizer.cpp
|
|
AMDILDevice.cpp
|
|
AMDILDeviceInfo.cpp
|
|
AMDILEvergreenDevice.cpp
|
|
AMDILFrameLowering.cpp
|
|
AMDILIntrinsicInfo.cpp
|
|
AMDILISelDAGToDAG.cpp
|
|
AMDILISelLowering.cpp
|
|
AMDILNIDevice.cpp
|
|
AMDILPeepholeOptimizer.cpp
|
|
AMDILSIDevice.cpp
|
|
AMDGPUAsmPrinter.cpp
|
|
AMDGPUMCInstLower.cpp
|
|
AMDGPUSubtarget.cpp
|
|
AMDGPUStructurizeCFG.cpp
|
|
AMDGPUTargetMachine.cpp
|
|
AMDGPUISelLowering.cpp
|
|
AMDGPUConvertToISA.cpp
|
|
AMDGPUInstrInfo.cpp
|
|
AMDGPURegisterInfo.cpp
|
|
R600ExpandSpecialInstrs.cpp
|
|
R600InstrInfo.cpp
|
|
R600ISelLowering.cpp
|
|
R600MachineFunctionInfo.cpp
|
|
R600RegisterInfo.cpp
|
|
SIAnnotateControlFlow.cpp
|
|
SIAssignInterpRegs.cpp
|
|
SIInstrInfo.cpp
|
|
SIISelLowering.cpp
|
|
SILowerLiteralConstants.cpp
|
|
SILowerControlFlow.cpp
|
|
SIMachineFunctionInfo.cpp
|
|
SIRegisterInfo.cpp
|
|
)
|
|
|
|
add_dependencies(LLVMR600CodeGen intrinsics_gen)
|
|
|
|
add_subdirectory(InstPrinter)
|
|
add_subdirectory(TargetInfo)
|
|
add_subdirectory(MCTargetDesc)
|