Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 1 | //===-- ARMMCTargetDesc.h - ARM Target Descriptions -------------*- C++ -*-===// |
| 2 | // |
| 3 | // The LLVM Compiler Infrastructure |
| 4 | // |
| 5 | // This file is distributed under the University of Illinois Open Source |
| 6 | // License. See LICENSE.TXT for details. |
| 7 | // |
| 8 | //===----------------------------------------------------------------------===// |
| 9 | // |
| 10 | // This file provides ARM specific target descriptions. |
| 11 | // |
| 12 | //===----------------------------------------------------------------------===// |
| 13 | |
| 14 | #ifndef ARMMCTARGETDESC_H |
| 15 | #define ARMMCTARGETDESC_H |
| 16 | |
NAKAMURA Takumi | 287bc6b | 2011-07-23 01:16:22 +0000 | [diff] [blame] | 17 | #include "llvm/Support/DataTypes.h" |
Evan Cheng | 2bd6536 | 2011-07-07 00:08:19 +0000 | [diff] [blame] | 18 | #include <string> |
| 19 | |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 20 | namespace llvm { |
Rafael Espindola | a17151a | 2013-10-08 13:08:17 +0000 | [diff] [blame] | 21 | class formatted_raw_ostream; |
Evan Cheng | 5928e69 | 2011-07-25 23:24:55 +0000 | [diff] [blame] | 22 | class MCAsmBackend; |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 23 | class MCCodeEmitter; |
| 24 | class MCContext; |
| 25 | class MCInstrInfo; |
Rafael Espindola | a17151a | 2013-10-08 13:08:17 +0000 | [diff] [blame] | 26 | class MCInstPrinter; |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 27 | class MCObjectWriter; |
Jim Grosbach | c3b0427 | 2012-05-15 17:35:52 +0000 | [diff] [blame] | 28 | class MCRegisterInfo; |
Evan Cheng | 4d1ca96 | 2011-07-08 01:53:10 +0000 | [diff] [blame] | 29 | class MCSubtargetInfo; |
Rafael Espindola | a17151a | 2013-10-08 13:08:17 +0000 | [diff] [blame] | 30 | class MCStreamer; |
Ahmed Bougacha | ad1084d | 2013-05-24 00:39:57 +0000 | [diff] [blame] | 31 | class MCRelocationInfo; |
Evan Cheng | 2bd6536 | 2011-07-07 00:08:19 +0000 | [diff] [blame] | 32 | class StringRef; |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 33 | class Target; |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 34 | class raw_ostream; |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 35 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame^] | 36 | extern Target TheARMLETarget, TheThumbLETarget; |
| 37 | extern Target TheARMBETarget, TheThumbBETarget; |
Evan Cheng | 2bd6536 | 2011-07-07 00:08:19 +0000 | [diff] [blame] | 38 | |
| 39 | namespace ARM_MC { |
Evan Cheng | 9f7ad31 | 2012-04-26 01:13:36 +0000 | [diff] [blame] | 40 | std::string ParseARMTriple(StringRef TT, StringRef CPU); |
Evan Cheng | 4d1ca96 | 2011-07-08 01:53:10 +0000 | [diff] [blame] | 41 | |
| 42 | /// createARMMCSubtargetInfo - Create a ARM MCSubtargetInfo instance. |
| 43 | /// This is exposed so Asm parser, etc. do not need to go through |
| 44 | /// TargetRegistry. |
| 45 | MCSubtargetInfo *createARMMCSubtargetInfo(StringRef TT, StringRef CPU, |
| 46 | StringRef FS); |
Evan Cheng | 2bd6536 | 2011-07-07 00:08:19 +0000 | [diff] [blame] | 47 | } |
| 48 | |
Rafael Espindola | a17151a | 2013-10-08 13:08:17 +0000 | [diff] [blame] | 49 | MCStreamer *createMCAsmStreamer(MCContext &Ctx, formatted_raw_ostream &OS, |
Rafael Espindola | b4eec1d | 2014-02-05 18:00:21 +0000 | [diff] [blame] | 50 | bool isVerboseAsm, bool useCFI, |
Rafael Espindola | a17151a | 2013-10-08 13:08:17 +0000 | [diff] [blame] | 51 | bool useDwarfDirectory, |
| 52 | MCInstPrinter *InstPrint, MCCodeEmitter *CE, |
| 53 | MCAsmBackend *TAB, bool ShowInst); |
| 54 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame^] | 55 | MCCodeEmitter *createARMLEMCCodeEmitter(const MCInstrInfo &MCII, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 56 | const MCRegisterInfo &MRI, |
| 57 | const MCSubtargetInfo &STI, |
| 58 | MCContext &Ctx); |
| 59 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame^] | 60 | MCCodeEmitter *createARMBEMCCodeEmitter(const MCInstrInfo &MCII, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 61 | const MCRegisterInfo &MRI, |
| 62 | const MCSubtargetInfo &STI, |
| 63 | MCContext &Ctx); |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 64 | |
Bill Wendling | 58e2d3d | 2013-09-09 02:37:14 +0000 | [diff] [blame] | 65 | MCAsmBackend *createARMAsmBackend(const Target &T, const MCRegisterInfo &MRI, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 66 | StringRef TT, StringRef CPU, |
| 67 | bool IsLittleEndian); |
| 68 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame^] | 69 | MCAsmBackend *createARMLEAsmBackend(const Target &T, const MCRegisterInfo &MRI, |
Bill Wendling | 58e2d3d | 2013-09-09 02:37:14 +0000 | [diff] [blame] | 70 | StringRef TT, StringRef CPU); |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 71 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame^] | 72 | MCAsmBackend *createARMBEAsmBackend(const Target &T, const MCRegisterInfo &MRI, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 73 | StringRef TT, StringRef CPU); |
| 74 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame^] | 75 | MCAsmBackend *createThumbLEAsmBackend(const Target &T, const MCRegisterInfo &MRI, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 76 | StringRef TT, StringRef CPU); |
| 77 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame^] | 78 | MCAsmBackend *createThumbBEAsmBackend(const Target &T, const MCRegisterInfo &MRI, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 79 | StringRef TT, StringRef CPU); |
| 80 | |
Rafael Espindola | a012405 | 2011-12-22 00:37:50 +0000 | [diff] [blame] | 81 | /// createARMELFObjectWriter - Construct an ELF Mach-O object writer. |
| 82 | MCObjectWriter *createARMELFObjectWriter(raw_ostream &OS, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 83 | uint8_t OSABI, |
| 84 | bool IsLittleEndian); |
Rafael Espindola | a012405 | 2011-12-22 00:37:50 +0000 | [diff] [blame] | 85 | |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 86 | /// createARMMachObjectWriter - Construct an ARM Mach-O object writer. |
| 87 | MCObjectWriter *createARMMachObjectWriter(raw_ostream &OS, |
| 88 | bool Is64Bit, |
| 89 | uint32_t CPUType, |
| 90 | uint32_t CPUSubtype); |
| 91 | |
Ahmed Bougacha | ad1084d | 2013-05-24 00:39:57 +0000 | [diff] [blame] | 92 | |
| 93 | /// createARMMachORelocationInfo - Construct ARM Mach-O relocation info. |
| 94 | MCRelocationInfo *createARMMachORelocationInfo(MCContext &Ctx); |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 95 | } // End llvm namespace |
| 96 | |
| 97 | // Defines symbolic names for ARM registers. This defines a mapping from |
| 98 | // register name to register number. |
| 99 | // |
| 100 | #define GET_REGINFO_ENUM |
| 101 | #include "ARMGenRegisterInfo.inc" |
| 102 | |
| 103 | // Defines symbolic names for the ARM instructions. |
| 104 | // |
| 105 | #define GET_INSTRINFO_ENUM |
| 106 | #include "ARMGenInstrInfo.inc" |
| 107 | |
Evan Cheng | bc153d4 | 2011-07-14 20:59:42 +0000 | [diff] [blame] | 108 | #define GET_SUBTARGETINFO_ENUM |
| 109 | #include "ARMGenSubtargetInfo.inc" |
| 110 | |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 111 | #endif |