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 | |
Benjamin Kramer | a7c40ef | 2014-08-13 16:26:38 +0000 | [diff] [blame] | 14 | #ifndef LLVM_LIB_TARGET_ARM_MCTARGETDESC_ARMMCTARGETDESC_H |
| 15 | #define LLVM_LIB_TARGET_ARM_MCTARGETDESC_ARMMCTARGETDESC_H |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 16 | |
NAKAMURA Takumi | 287bc6b | 2011-07-23 01:16:22 +0000 | [diff] [blame] | 17 | #include "llvm/Support/DataTypes.h" |
Lang Hames | 232cdb4 | 2017-10-10 16:59:01 +0000 | [diff] [blame^] | 18 | #include <memory> |
Evan Cheng | 2bd6536 | 2011-07-07 00:08:19 +0000 | [diff] [blame] | 19 | #include <string> |
| 20 | |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 21 | namespace llvm { |
Rafael Espindola | a17151a | 2013-10-08 13:08:17 +0000 | [diff] [blame] | 22 | class formatted_raw_ostream; |
Evan Cheng | 5928e69 | 2011-07-25 23:24:55 +0000 | [diff] [blame] | 23 | class MCAsmBackend; |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 24 | class MCCodeEmitter; |
| 25 | class MCContext; |
| 26 | class MCInstrInfo; |
Rafael Espindola | a17151a | 2013-10-08 13:08:17 +0000 | [diff] [blame] | 27 | class MCInstPrinter; |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 28 | class MCObjectWriter; |
Jim Grosbach | c3b0427 | 2012-05-15 17:35:52 +0000 | [diff] [blame] | 29 | class MCRegisterInfo; |
Evan Cheng | 4d1ca96 | 2011-07-08 01:53:10 +0000 | [diff] [blame] | 30 | class MCSubtargetInfo; |
Rafael Espindola | a17151a | 2013-10-08 13:08:17 +0000 | [diff] [blame] | 31 | class MCStreamer; |
Joel Jones | 373d7d3 | 2016-07-25 17:18:28 +0000 | [diff] [blame] | 32 | class MCTargetOptions; |
Ahmed Bougacha | ad1084d | 2013-05-24 00:39:57 +0000 | [diff] [blame] | 33 | class MCRelocationInfo; |
Peter Collingbourne | 20c7259 | 2015-02-19 00:45:02 +0000 | [diff] [blame] | 34 | class MCTargetStreamer; |
Evan Cheng | 2bd6536 | 2011-07-07 00:08:19 +0000 | [diff] [blame] | 35 | class StringRef; |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 36 | class Target; |
Daniel Sanders | 50f1723 | 2015-09-15 16:17:27 +0000 | [diff] [blame] | 37 | class Triple; |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 38 | class raw_ostream; |
Rafael Espindola | 5560a4c | 2015-04-14 22:14:34 +0000 | [diff] [blame] | 39 | class raw_pwrite_stream; |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 40 | |
Mehdi Amini | f42454b | 2016-10-09 23:00:34 +0000 | [diff] [blame] | 41 | Target &getTheARMLETarget(); |
| 42 | Target &getTheThumbLETarget(); |
| 43 | Target &getTheARMBETarget(); |
| 44 | Target &getTheThumbBETarget(); |
Evan Cheng | 2bd6536 | 2011-07-07 00:08:19 +0000 | [diff] [blame] | 45 | |
| 46 | namespace ARM_MC { |
Daniel Sanders | 50f1723 | 2015-09-15 16:17:27 +0000 | [diff] [blame] | 47 | std::string ParseARMTriple(const Triple &TT, StringRef CPU); |
Evan Cheng | 4d1ca96 | 2011-07-08 01:53:10 +0000 | [diff] [blame] | 48 | |
Daniel Sanders | a73f1fd | 2015-06-10 12:11:26 +0000 | [diff] [blame] | 49 | /// Create a ARM MCSubtargetInfo instance. This is exposed so Asm parser, etc. |
| 50 | /// do not need to go through TargetRegistry. |
Daniel Sanders | 50f1723 | 2015-09-15 16:17:27 +0000 | [diff] [blame] | 51 | MCSubtargetInfo *createARMMCSubtargetInfo(const Triple &TT, StringRef CPU, |
Daniel Sanders | a73f1fd | 2015-06-10 12:11:26 +0000 | [diff] [blame] | 52 | StringRef FS); |
Evan Cheng | 2bd6536 | 2011-07-07 00:08:19 +0000 | [diff] [blame] | 53 | } |
| 54 | |
Peter Collingbourne | 20c7259 | 2015-02-19 00:45:02 +0000 | [diff] [blame] | 55 | MCTargetStreamer *createARMNullTargetStreamer(MCStreamer &S); |
Rafael Espindola | 73870dd | 2015-03-16 21:43:42 +0000 | [diff] [blame] | 56 | MCTargetStreamer *createARMTargetAsmStreamer(MCStreamer &S, |
| 57 | formatted_raw_ostream &OS, |
| 58 | MCInstPrinter *InstPrint, |
| 59 | bool isVerboseAsm); |
Rafael Espindola | cd584a8 | 2015-03-19 01:50:16 +0000 | [diff] [blame] | 60 | MCTargetStreamer *createARMObjectTargetStreamer(MCStreamer &S, |
| 61 | const MCSubtargetInfo &STI); |
Peter Collingbourne | 20c7259 | 2015-02-19 00:45:02 +0000 | [diff] [blame] | 62 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame] | 63 | MCCodeEmitter *createARMLEMCCodeEmitter(const MCInstrInfo &MCII, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 64 | const MCRegisterInfo &MRI, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 65 | MCContext &Ctx); |
| 66 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame] | 67 | MCCodeEmitter *createARMBEMCCodeEmitter(const MCInstrInfo &MCII, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 68 | const MCRegisterInfo &MRI, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 69 | MCContext &Ctx); |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 70 | |
Bill Wendling | 58e2d3d | 2013-09-09 02:37:14 +0000 | [diff] [blame] | 71 | MCAsmBackend *createARMAsmBackend(const Target &T, const MCRegisterInfo &MRI, |
Daniel Sanders | 50f1723 | 2015-09-15 16:17:27 +0000 | [diff] [blame] | 72 | const Triple &TT, StringRef CPU, |
Joel Jones | 373d7d3 | 2016-07-25 17:18:28 +0000 | [diff] [blame] | 73 | const MCTargetOptions &Options, |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 74 | bool IsLittleEndian); |
| 75 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame] | 76 | MCAsmBackend *createARMLEAsmBackend(const Target &T, const MCRegisterInfo &MRI, |
Joel Jones | 373d7d3 | 2016-07-25 17:18:28 +0000 | [diff] [blame] | 77 | const Triple &TT, StringRef CPU, |
| 78 | const MCTargetOptions &Options); |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 79 | |
Christian Pirker | dc9ff75 | 2014-04-01 15:19:30 +0000 | [diff] [blame] | 80 | MCAsmBackend *createARMBEAsmBackend(const Target &T, const MCRegisterInfo &MRI, |
Joel Jones | 373d7d3 | 2016-07-25 17:18:28 +0000 | [diff] [blame] | 81 | const Triple &TT, StringRef CPU, |
| 82 | const MCTargetOptions &Options); |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 83 | |
Daniel Sanders | 418caf5 | 2015-06-10 10:35:34 +0000 | [diff] [blame] | 84 | MCAsmBackend *createThumbLEAsmBackend(const Target &T, |
| 85 | const MCRegisterInfo &MRI, |
Joel Jones | 373d7d3 | 2016-07-25 17:18:28 +0000 | [diff] [blame] | 86 | const Triple &TT, StringRef CPU, |
| 87 | const MCTargetOptions &Options); |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 88 | |
Daniel Sanders | 418caf5 | 2015-06-10 10:35:34 +0000 | [diff] [blame] | 89 | MCAsmBackend *createThumbBEAsmBackend(const Target &T, |
| 90 | const MCRegisterInfo &MRI, |
Joel Jones | 373d7d3 | 2016-07-25 17:18:28 +0000 | [diff] [blame] | 91 | const Triple &TT, StringRef CPU, |
| 92 | const MCTargetOptions &Options); |
Christian Pirker | 2a11160 | 2014-03-28 14:35:30 +0000 | [diff] [blame] | 93 | |
Rafael Espindola | cd584a8 | 2015-03-19 01:50:16 +0000 | [diff] [blame] | 94 | // Construct a PE/COFF machine code streamer which will generate a PE/COFF |
| 95 | // object file. |
Saleem Abdulrasool | 84b952b | 2014-04-27 03:48:22 +0000 | [diff] [blame] | 96 | MCStreamer *createARMWinCOFFStreamer(MCContext &Context, MCAsmBackend &MAB, |
Rafael Espindola | 5560a4c | 2015-04-14 22:14:34 +0000 | [diff] [blame] | 97 | raw_pwrite_stream &OS, |
David Majnemer | 03e2cc3 | 2015-12-21 22:09:27 +0000 | [diff] [blame] | 98 | MCCodeEmitter *Emitter, bool RelaxAll, |
| 99 | bool IncrementalLinkerCompatible); |
Saleem Abdulrasool | 84b952b | 2014-04-27 03:48:22 +0000 | [diff] [blame] | 100 | |
Rafael Espindola | df7305a | 2015-04-09 17:10:57 +0000 | [diff] [blame] | 101 | /// Construct an ELF Mach-O object writer. |
Lang Hames | 60fbc7c | 2017-10-10 16:28:07 +0000 | [diff] [blame] | 102 | std::unique_ptr<MCObjectWriter> createARMELFObjectWriter(raw_pwrite_stream &OS, |
| 103 | uint8_t OSABI, |
| 104 | bool IsLittleEndian); |
Rafael Espindola | a012405 | 2011-12-22 00:37:50 +0000 | [diff] [blame] | 105 | |
Rafael Espindola | df7305a | 2015-04-09 17:10:57 +0000 | [diff] [blame] | 106 | /// Construct an ARM Mach-O object writer. |
Lang Hames | 60fbc7c | 2017-10-10 16:28:07 +0000 | [diff] [blame] | 107 | std::unique_ptr<MCObjectWriter> createARMMachObjectWriter(raw_pwrite_stream &OS, |
| 108 | bool Is64Bit, |
| 109 | uint32_t CPUType, |
| 110 | uint32_t CPUSubtype); |
Evan Cheng | ad5f485 | 2011-07-23 00:00:19 +0000 | [diff] [blame] | 111 | |
Rafael Espindola | df7305a | 2015-04-09 17:10:57 +0000 | [diff] [blame] | 112 | /// Construct an ARM PE/COFF object writer. |
Lang Hames | 60fbc7c | 2017-10-10 16:28:07 +0000 | [diff] [blame] | 113 | std::unique_ptr<MCObjectWriter> |
| 114 | createARMWinCOFFObjectWriter(raw_pwrite_stream &OS, bool Is64Bit); |
Ahmed Bougacha | ad1084d | 2013-05-24 00:39:57 +0000 | [diff] [blame] | 115 | |
Rafael Espindola | df7305a | 2015-04-09 17:10:57 +0000 | [diff] [blame] | 116 | /// Construct ARM Mach-O relocation info. |
Ahmed Bougacha | ad1084d | 2013-05-24 00:39:57 +0000 | [diff] [blame] | 117 | MCRelocationInfo *createARMMachORelocationInfo(MCContext &Ctx); |
Alexander Kornienko | f00654e | 2015-06-23 09:49:53 +0000 | [diff] [blame] | 118 | } // End llvm namespace |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 119 | |
| 120 | // Defines symbolic names for ARM registers. This defines a mapping from |
| 121 | // register name to register number. |
| 122 | // |
| 123 | #define GET_REGINFO_ENUM |
| 124 | #include "ARMGenRegisterInfo.inc" |
| 125 | |
| 126 | // Defines symbolic names for the ARM instructions. |
| 127 | // |
| 128 | #define GET_INSTRINFO_ENUM |
| 129 | #include "ARMGenInstrInfo.inc" |
| 130 | |
Evan Cheng | bc153d4 | 2011-07-14 20:59:42 +0000 | [diff] [blame] | 131 | #define GET_SUBTARGETINFO_ENUM |
| 132 | #include "ARMGenSubtargetInfo.inc" |
| 133 | |
Evan Cheng | 928ce72 | 2011-07-06 22:02:34 +0000 | [diff] [blame] | 134 | #endif |