1 //===-- AMDGPUMCTargetDesc.h - AMDGPU Target Descriptions -----*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
11 /// Provides AMDGPU specific target descriptions.
13 //===----------------------------------------------------------------------===//
16 #ifndef LLVM_LIB_TARGET_AMDGPU_MCTARGETDESC_AMDGPUMCTARGETDESC_H
17 #define LLVM_LIB_TARGET_AMDGPU_MCTARGETDESC_AMDGPUMCTARGETDESC_H
19 #include "llvm/Support/DataTypes.h"
28 class MCObjectTargetWriter
;
30 class MCSubtargetInfo
;
31 class MCTargetOptions
;
35 class raw_pwrite_stream
;
37 Target
&getTheAMDGPUTarget();
38 Target
&getTheGCNTarget();
40 MCCodeEmitter
*createR600MCCodeEmitter(const MCInstrInfo
&MCII
,
41 const MCRegisterInfo
&MRI
,
43 MCInstrInfo
*createR600MCInstrInfo();
45 MCCodeEmitter
*createSIMCCodeEmitter(const MCInstrInfo
&MCII
,
46 const MCRegisterInfo
&MRI
,
49 MCAsmBackend
*createAMDGPUAsmBackend(const Target
&T
,
50 const MCSubtargetInfo
&STI
,
51 const MCRegisterInfo
&MRI
,
52 const MCTargetOptions
&Options
);
54 std::unique_ptr
<MCObjectTargetWriter
>
55 createAMDGPUELFObjectWriter(bool Is64Bit
, uint8_t OSABI
,
56 bool HasRelocationAddend
);
57 } // End llvm namespace
59 #define GET_REGINFO_ENUM
60 #include "AMDGPUGenRegisterInfo.inc"
61 #undef GET_REGINFO_ENUM
63 #define GET_REGINFO_ENUM
64 #include "R600GenRegisterInfo.inc"
65 #undef GET_REGINFO_ENUM
67 #define GET_INSTRINFO_ENUM
68 #define GET_INSTRINFO_OPERAND_ENUM
69 #define GET_INSTRINFO_SCHED_ENUM
70 #include "AMDGPUGenInstrInfo.inc"
71 #undef GET_INSTRINFO_SCHED_ENUM
72 #undef GET_INSTRINFO_OPERAND_ENUM
73 #undef GET_INSTRINFO_ENUM
75 #define GET_INSTRINFO_ENUM
76 #define GET_INSTRINFO_OPERAND_ENUM
77 #define GET_INSTRINFO_SCHED_ENUM
78 #include "R600GenInstrInfo.inc"
79 #undef GET_INSTRINFO_SCHED_ENUM
80 #undef GET_INSTRINFO_OPERAND_ENUM
81 #undef GET_INSTRINFO_ENUM
83 #define GET_SUBTARGETINFO_ENUM
84 #include "AMDGPUGenSubtargetInfo.inc"
85 #undef GET_SUBTARGETINFO_ENUM
87 #define GET_SUBTARGETINFO_ENUM
88 #include "R600GenSubtargetInfo.inc"
89 #undef GET_SUBTARGETINFO_ENUM