blob: 05bbf396944d414b4185e08cd49867e01bebd7be [file] [log] [blame]
Craig Topperf3f66502012-03-17 09:39:20 +00001//===-- HexagonMCTargetDesc.cpp - Hexagon Target Descriptions -------------===//
Tony Linthicumb3705e02011-12-15 22:29:08 +00002//
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//
Craig Topperbc3168b2012-03-17 09:28:37 +000010// This file provides Hexagon specific target descriptions.
Tony Linthicumb3705e02011-12-15 22:29:08 +000011//
12//===----------------------------------------------------------------------===//
13
Chandler Carruth6bda14b2017-06-06 11:49:48 +000014#include "MCTargetDesc/HexagonMCTargetDesc.h"
Eugene Zelenko401f3812016-12-17 01:29:35 +000015#include "Hexagon.h"
Eugene Zelenko58655bb2016-12-17 01:09:05 +000016#include "HexagonTargetStreamer.h"
Colin LeMahieuff062612014-11-20 21:56:35 +000017#include "MCTargetDesc/HexagonInstPrinter.h"
Eugene Zelenko58655bb2016-12-17 01:09:05 +000018#include "MCTargetDesc/HexagonMCAsmInfo.h"
19#include "MCTargetDesc/HexagonMCELFStreamer.h"
Eugene Zelenko50156892016-12-17 01:17:18 +000020#include "MCTargetDesc/HexagonMCInstrInfo.h"
Eugene Zelenko58655bb2016-12-17 01:09:05 +000021#include "llvm/ADT/StringRef.h"
Zachary Turner264b5d92017-06-07 03:48:56 +000022#include "llvm/BinaryFormat/ELF.h"
Lang Hames02d33052017-10-11 01:57:21 +000023#include "llvm/MC/MCAsmBackend.h"
Lang Hames2241ffa2017-10-11 23:34:47 +000024#include "llvm/MC/MCCodeEmitter.h"
Colin LeMahieube99a022015-06-17 03:06:16 +000025#include "llvm/MC/MCContext.h"
Eugene Zelenko58655bb2016-12-17 01:09:05 +000026#include "llvm/MC/MCDwarf.h"
Colin LeMahieu2c769202014-11-06 17:05:51 +000027#include "llvm/MC/MCELFStreamer.h"
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +000028#include "llvm/MC/MCInstrAnalysis.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000029#include "llvm/MC/MCInstrInfo.h"
30#include "llvm/MC/MCRegisterInfo.h"
Jyotsna Verma7503a622013-02-20 16:13:27 +000031#include "llvm/MC/MCStreamer.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000032#include "llvm/MC/MCSubtargetInfo.h"
Craig Topperc4965bc2012-02-05 07:21:30 +000033#include "llvm/Support/ErrorHandling.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000034#include "llvm/Support/TargetRegistry.h"
Chandler Carruth6bda14b2017-06-06 11:49:48 +000035#include "llvm/Support/raw_ostream.h"
Eugene Zelenko58655bb2016-12-17 01:09:05 +000036#include <cassert>
37#include <cstdint>
38#include <new>
39#include <string>
Tony Linthicumb3705e02011-12-15 22:29:08 +000040
Chandler Carruthd174b722014-04-22 02:03:14 +000041using namespace llvm;
42
Tony Linthicumb3705e02011-12-15 22:29:08 +000043#define GET_INSTRINFO_MC_DESC
44#include "HexagonGenInstrInfo.inc"
45
46#define GET_SUBTARGETINFO_MC_DESC
47#include "HexagonGenSubtargetInfo.inc"
48
49#define GET_REGINFO_MC_DESC
50#include "HexagonGenRegisterInfo.inc"
51
Colin LeMahieu7cd08922015-11-09 04:07:48 +000052cl::opt<bool> llvm::HexagonDisableCompound
53 ("mno-compound",
54 cl::desc("Disable looking for compound instructions for Hexagon"));
55
56cl::opt<bool> llvm::HexagonDisableDuplex
57 ("mno-pairing",
58 cl::desc("Disable looking for duplex instructions for Hexagon"));
59
Krzysztof Parzyszek64d4e2b2016-04-20 21:17:40 +000060static cl::opt<bool> HexagonV4ArchVariant("mv4", cl::Hidden, cl::init(false),
61 cl::desc("Build for Hexagon V4"));
62
63static cl::opt<bool> HexagonV5ArchVariant("mv5", cl::Hidden, cl::init(false),
64 cl::desc("Build for Hexagon V5"));
65
66static cl::opt<bool> HexagonV55ArchVariant("mv55", cl::Hidden, cl::init(false),
67 cl::desc("Build for Hexagon V55"));
68
69static cl::opt<bool> HexagonV60ArchVariant("mv60", cl::Hidden, cl::init(false),
70 cl::desc("Build for Hexagon V60"));
71
Krzysztof Parzyszekf9015e62017-02-10 23:46:45 +000072static cl::opt<bool> HexagonV62ArchVariant("mv62", cl::Hidden, cl::init(false),
73 cl::desc("Build for Hexagon V62"));
74
Krzysztof Parzyszek7a0981a2017-03-09 17:05:11 +000075static cl::opt<bool> EnableHVX("mhvx", cl::Hidden, cl::init(false),
76 cl::desc("Enable Hexagon Vector Extension (HVX)"));
77
Krzysztof Parzyszek64d4e2b2016-04-20 21:17:40 +000078static StringRef DefaultArch = "hexagonv60";
79
80static StringRef HexagonGetArchVariant() {
81 if (HexagonV4ArchVariant)
82 return "hexagonv4";
83 if (HexagonV5ArchVariant)
84 return "hexagonv5";
85 if (HexagonV55ArchVariant)
86 return "hexagonv55";
87 if (HexagonV60ArchVariant)
88 return "hexagonv60";
Krzysztof Parzyszekf9015e62017-02-10 23:46:45 +000089 if (HexagonV62ArchVariant)
90 return "hexagonv62";
Krzysztof Parzyszek64d4e2b2016-04-20 21:17:40 +000091 return "";
92}
93
Krzysztof Parzyszek75e74ee2016-08-19 14:09:47 +000094StringRef Hexagon_MC::selectHexagonCPU(const Triple &TT, StringRef CPU) {
Krzysztof Parzyszek64d4e2b2016-04-20 21:17:40 +000095 StringRef ArchV = HexagonGetArchVariant();
96 if (!ArchV.empty() && !CPU.empty()) {
97 if (ArchV != CPU)
98 report_fatal_error("conflicting architectures specified.");
99 return CPU;
100 }
101 if (ArchV.empty()) {
102 if (CPU.empty())
103 CPU = DefaultArch;
104 return CPU;
105 }
106 return ArchV;
Krzysztof Parzyszek759a7d02015-12-14 15:03:54 +0000107}
108
Benjamin Kramerefcf06f2017-02-11 11:06:55 +0000109unsigned llvm::HexagonGetLastSlot() { return HexagonItinerariesV4FU::SLOT3; }
Tony Linthicumb3705e02011-12-15 22:29:08 +0000110
Colin LeMahieube99a022015-06-17 03:06:16 +0000111namespace {
Eugene Zelenko58655bb2016-12-17 01:09:05 +0000112
Colin LeMahieud2158752015-06-18 20:43:50 +0000113class HexagonTargetAsmStreamer : public HexagonTargetStreamer {
Colin LeMahieud2158752015-06-18 20:43:50 +0000114public:
115 HexagonTargetAsmStreamer(MCStreamer &S,
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000116 formatted_raw_ostream &OS,
117 bool isVerboseAsm,
118 MCInstPrinter &IP)
Colin LeMahieufa389722015-06-18 21:03:13 +0000119 : HexagonTargetStreamer(S) {}
Eugene Zelenko58655bb2016-12-17 01:09:05 +0000120
Colin LeMahieud2158752015-06-18 20:43:50 +0000121 void prettyPrintAsm(MCInstPrinter &InstPrinter, raw_ostream &OS,
122 const MCInst &Inst, const MCSubtargetInfo &STI) override {
123 assert(HexagonMCInstrInfo::isBundle(Inst));
124 assert(HexagonMCInstrInfo::bundleSize(Inst) <= HEXAGON_PACKET_SIZE);
125 std::string Buffer;
126 {
127 raw_string_ostream TempStream(Buffer);
128 InstPrinter.printInst(&Inst, TempStream, "", STI);
129 }
130 StringRef Contents(Buffer);
131 auto PacketBundle = Contents.rsplit('\n');
132 auto HeadTail = PacketBundle.first.split('\n');
Colin LeMahieub7a5f9f2015-11-10 00:22:00 +0000133 StringRef Separator = "\n";
134 StringRef Indent = "\t\t";
135 OS << "\t{\n";
136 while (!HeadTail.first.empty()) {
137 StringRef InstTxt;
Colin LeMahieud2158752015-06-18 20:43:50 +0000138 auto Duplex = HeadTail.first.split('\v');
Colin LeMahieub7a5f9f2015-11-10 00:22:00 +0000139 if (!Duplex.second.empty()) {
140 OS << Indent << Duplex.first << Separator;
141 InstTxt = Duplex.second;
142 } else if (!HeadTail.first.trim().startswith("immext")) {
143 InstTxt = Duplex.first;
Colin LeMahieud2158752015-06-18 20:43:50 +0000144 }
Colin LeMahieub7a5f9f2015-11-10 00:22:00 +0000145 if (!InstTxt.empty())
146 OS << Indent << InstTxt << Separator;
Colin LeMahieud2158752015-06-18 20:43:50 +0000147 HeadTail = HeadTail.second.split('\n');
Colin LeMahieud2158752015-06-18 20:43:50 +0000148 }
Colin LeMahieub7a5f9f2015-11-10 00:22:00 +0000149 OS << "\t}" << PacketBundle.second;
Colin LeMahieud2158752015-06-18 20:43:50 +0000150 }
151};
Colin LeMahieud2158752015-06-18 20:43:50 +0000152
Colin LeMahieube99a022015-06-17 03:06:16 +0000153class HexagonTargetELFStreamer : public HexagonTargetStreamer {
154public:
Eugene Zelenko58655bb2016-12-17 01:09:05 +0000155 MCELFStreamer &getStreamer() {
156 return static_cast<MCELFStreamer &>(Streamer);
157 }
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000158 HexagonTargetELFStreamer(MCStreamer &S, MCSubtargetInfo const &STI)
159 : HexagonTargetStreamer(S) {
160 MCAssembler &MCA = getStreamer().getAssembler();
161 MCA.setELFHeaderEFlags(Hexagon_MC::GetELFFlags(STI));
162 }
163
Eugene Zelenko58655bb2016-12-17 01:09:05 +0000164
Colin LeMahieube99a022015-06-17 03:06:16 +0000165 void EmitCommonSymbolSorted(MCSymbol *Symbol, uint64_t Size,
166 unsigned ByteAlignment,
167 unsigned AccessSize) override {
168 HexagonMCELFStreamer &HexagonELFStreamer =
169 static_cast<HexagonMCELFStreamer &>(getStreamer());
170 HexagonELFStreamer.HexagonMCEmitCommonSymbol(Symbol, Size, ByteAlignment,
171 AccessSize);
172 }
Eugene Zelenko58655bb2016-12-17 01:09:05 +0000173
Colin LeMahieube99a022015-06-17 03:06:16 +0000174 void EmitLocalCommonSymbolSorted(MCSymbol *Symbol, uint64_t Size,
175 unsigned ByteAlignment,
176 unsigned AccessSize) override {
177 HexagonMCELFStreamer &HexagonELFStreamer =
178 static_cast<HexagonMCELFStreamer &>(getStreamer());
179 HexagonELFStreamer.HexagonMCEmitLocalCommonSymbol(
180 Symbol, Size, ByteAlignment, AccessSize);
181 }
182};
Eugene Zelenko58655bb2016-12-17 01:09:05 +0000183
184} // end anonymous namespace
Colin LeMahieube99a022015-06-17 03:06:16 +0000185
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000186llvm::MCInstrInfo *llvm::createHexagonMCInstrInfo() {
187 MCInstrInfo *X = new MCInstrInfo();
188 InitHexagonMCInstrInfo(X);
189 return X;
190}
191
192static MCRegisterInfo *createHexagonMCRegisterInfo(const Triple &TT) {
193 MCRegisterInfo *X = new MCRegisterInfo();
194 InitHexagonMCRegisterInfo(X, Hexagon::R31);
195 return X;
196}
197
Rafael Espindola227144c2013-05-13 01:16:13 +0000198static MCAsmInfo *createHexagonMCAsmInfo(const MCRegisterInfo &MRI,
Daniel Sanders50f17232015-09-15 16:17:27 +0000199 const Triple &TT) {
Rafael Espindola140a8372013-05-10 18:16:59 +0000200 MCAsmInfo *MAI = new HexagonMCAsmInfo(TT);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000201
202 // VirtualFP = (R30 + #0).
Sid Manning7da3f9a2014-10-03 13:18:11 +0000203 MCCFIInstruction Inst =
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000204 MCCFIInstruction::createDefCfa(nullptr,
205 MRI.getDwarfRegNum(Hexagon::R30, true), 0);
Rafael Espindola227144c2013-05-13 01:16:13 +0000206 MAI->addInitialFrameState(Inst);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000207
208 return MAI;
209}
210
Daniel Sanders50f17232015-09-15 16:17:27 +0000211static MCInstPrinter *createHexagonMCInstPrinter(const Triple &T,
Eric Christopherf8019402015-03-31 00:10:04 +0000212 unsigned SyntaxVariant,
Sid Manning12cd21a2014-10-15 18:27:40 +0000213 const MCAsmInfo &MAI,
214 const MCInstrInfo &MII,
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000215 const MCRegisterInfo &MRI)
216{
Eric Christopherfbe80f52015-04-09 19:20:37 +0000217 if (SyntaxVariant == 0)
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000218 return new HexagonInstPrinter(MAI, MII, MRI);
Eric Christopherfbe80f52015-04-09 19:20:37 +0000219 else
Colin LeMahieube99a022015-06-17 03:06:16 +0000220 return nullptr;
221}
222
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000223static MCTargetStreamer *
224createMCAsmTargetStreamer(MCStreamer &S, formatted_raw_ostream &OS,
225 MCInstPrinter *IP, bool IsVerboseAsm) {
226 return new HexagonTargetAsmStreamer(S, OS, IsVerboseAsm, *IP);
Colin LeMahieud2158752015-06-18 20:43:50 +0000227}
228
Lang Hames02d33052017-10-11 01:57:21 +0000229static MCStreamer *createMCStreamer(Triple const &T, MCContext &Context,
230 std::unique_ptr<MCAsmBackend> &&MAB,
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000231 raw_pwrite_stream &OS,
Lang Hames2241ffa2017-10-11 23:34:47 +0000232 std::unique_ptr<MCCodeEmitter> &&Emitter,
233 bool RelaxAll) {
234 return createHexagonELFStreamer(T, Context, std::move(MAB), OS,
235 std::move(Emitter));
Colin LeMahieube99a022015-06-17 03:06:16 +0000236}
237
238static MCTargetStreamer *
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000239createHexagonObjectTargetStreamer(MCStreamer &S, const MCSubtargetInfo &STI) {
Colin LeMahieube99a022015-06-17 03:06:16 +0000240 return new HexagonTargetELFStreamer(S, STI);
Sid Manning12cd21a2014-10-15 18:27:40 +0000241}
Tony Linthicumb3705e02011-12-15 22:29:08 +0000242
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000243static void LLVM_ATTRIBUTE_UNUSED clearFeature(MCSubtargetInfo* STI, uint64_t F) {
244 uint64_t FB = STI->getFeatureBits().to_ullong();
245 if (FB & (1ULL << F))
246 STI->ToggleFeature(F);
247}
248
249static bool LLVM_ATTRIBUTE_UNUSED checkFeature(MCSubtargetInfo* STI, uint64_t F) {
250 uint64_t FB = STI->getFeatureBits().to_ullong();
251 return (FB & (1ULL << F)) != 0;
252}
253
254StringRef Hexagon_MC::ParseHexagonTriple(const Triple &TT, StringRef CPU) {
255 StringRef CPUName = Hexagon_MC::selectHexagonCPU(TT, CPU);
256 StringRef FS = "";
Krzysztof Parzyszek7a0981a2017-03-09 17:05:11 +0000257 if (EnableHVX) {
258 if (CPUName.equals_lower("hexagonv60") ||
259 CPUName.equals_lower("hexagonv62"))
260 FS = "+hvx";
261 }
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000262 return FS;
263}
264
265static bool isCPUValid(std::string CPU)
266{
267 std::vector<std::string> table
268 {
269 "hexagonv4",
270 "hexagonv5",
271 "hexagonv55",
272 "hexagonv60",
Krzysztof Parzyszekf9015e62017-02-10 23:46:45 +0000273 "hexagonv62",
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000274 };
275
276 return std::find(table.begin(), table.end(), CPU) != table.end();
277}
278
279MCSubtargetInfo *Hexagon_MC::createHexagonMCSubtargetInfo(const Triple &TT,
280 StringRef CPU,
281 StringRef FS) {
282 StringRef ArchFS = (FS.size()) ? FS : Hexagon_MC::ParseHexagonTriple(TT, CPU);
283 StringRef CPUName = Hexagon_MC::selectHexagonCPU(TT, CPU);
Krzysztof Parzyszekf9015e62017-02-10 23:46:45 +0000284 if (!isCPUValid(CPUName.str())) {
285 errs() << "error: invalid CPU \"" << CPUName.str().c_str()
286 << "\" specified\n";
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000287 return nullptr;
288 }
289
290 MCSubtargetInfo *X = createHexagonMCSubtargetInfoImpl(TT, CPUName, ArchFS);
291 if (X->getFeatureBits()[Hexagon::ExtensionHVXDbl]) {
292 llvm::FeatureBitset Features = X->getFeatureBits();
293 X->setFeatureBits(Features.set(Hexagon::ExtensionHVX));
294 }
295 return X;
296}
297
298unsigned Hexagon_MC::GetELFFlags(const MCSubtargetInfo &STI) {
299 static std::map<StringRef,unsigned> ElfFlags = {
300 {"hexagonv4", ELF::EF_HEXAGON_MACH_V4},
301 {"hexagonv5", ELF::EF_HEXAGON_MACH_V5},
302 {"hexagonv55", ELF::EF_HEXAGON_MACH_V55},
303 {"hexagonv60", ELF::EF_HEXAGON_MACH_V60},
Krzysztof Parzyszekf9015e62017-02-10 23:46:45 +0000304 {"hexagonv62", ELF::EF_HEXAGON_MACH_V62},
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000305 };
306
307 auto F = ElfFlags.find(STI.getCPU());
308 assert(F != ElfFlags.end() && "Unrecognized Architecture");
309 return F->second;
310}
311
312namespace {
313class HexagonMCInstrAnalysis : public MCInstrAnalysis {
314public:
315 HexagonMCInstrAnalysis(MCInstrInfo const *Info) : MCInstrAnalysis(Info) {}
316
317 bool isUnconditionalBranch(MCInst const &Inst) const override {
318 //assert(!HexagonMCInstrInfo::isBundle(Inst));
319 return MCInstrAnalysis::isUnconditionalBranch(Inst);
320 }
321
322 bool isConditionalBranch(MCInst const &Inst) const override {
323 //assert(!HexagonMCInstrInfo::isBundle(Inst));
324 return MCInstrAnalysis::isConditionalBranch(Inst);
325 }
326
327 bool evaluateBranch(MCInst const &Inst, uint64_t Addr,
328 uint64_t Size, uint64_t &Target) const override {
329 //assert(!HexagonMCInstrInfo::isBundle(Inst));
330 if(!HexagonMCInstrInfo::isExtendable(*Info, Inst))
331 return false;
332 auto const &Extended(HexagonMCInstrInfo::getExtendableOperand(*Info, Inst));
333 assert(Extended.isExpr());
334 int64_t Value;
335 if(!Extended.getExpr()->evaluateAsAbsolute(Value))
336 return false;
337 Target = Value;
338 return true;
339 }
340};
341}
342
343static MCInstrAnalysis *createHexagonMCInstrAnalysis(const MCInstrInfo *Info) {
344 return new HexagonMCInstrAnalysis(Info);
345}
346
Tony Linthicumb3705e02011-12-15 22:29:08 +0000347// Force static initialization.
348extern "C" void LLVMInitializeHexagonTargetMC() {
349 // Register the MC asm info.
Mehdi Aminif42454b2016-10-09 23:00:34 +0000350 RegisterMCAsmInfoFn X(getTheHexagonTarget(), createHexagonMCAsmInfo);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000351
Tony Linthicumb3705e02011-12-15 22:29:08 +0000352 // Register the MC instruction info.
Mehdi Aminif42454b2016-10-09 23:00:34 +0000353 TargetRegistry::RegisterMCInstrInfo(getTheHexagonTarget(),
Sid Manning7da3f9a2014-10-03 13:18:11 +0000354 createHexagonMCInstrInfo);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000355
356 // Register the MC register info.
Mehdi Aminif42454b2016-10-09 23:00:34 +0000357 TargetRegistry::RegisterMCRegInfo(getTheHexagonTarget(),
Tony Linthicumb3705e02011-12-15 22:29:08 +0000358 createHexagonMCRegisterInfo);
359
360 // Register the MC subtarget info.
Mehdi Aminif42454b2016-10-09 23:00:34 +0000361 TargetRegistry::RegisterMCSubtargetInfo(getTheHexagonTarget(),
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000362 Hexagon_MC::createHexagonMCSubtargetInfo);
Sid Manning7da3f9a2014-10-03 13:18:11 +0000363
364 // Register the MC Code Emitter
Mehdi Aminif42454b2016-10-09 23:00:34 +0000365 TargetRegistry::RegisterMCCodeEmitter(getTheHexagonTarget(),
Sid Manning7da3f9a2014-10-03 13:18:11 +0000366 createHexagonMCCodeEmitter);
Sid Manning12cd21a2014-10-15 18:27:40 +0000367
Colin LeMahieua6750772015-06-03 17:34:16 +0000368 // Register the asm backend
Mehdi Aminif42454b2016-10-09 23:00:34 +0000369 TargetRegistry::RegisterMCAsmBackend(getTheHexagonTarget(),
Colin LeMahieua6750772015-06-03 17:34:16 +0000370 createHexagonAsmBackend);
371
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000372
373 // Register the MC instruction analyzer.
374 TargetRegistry::RegisterMCInstrAnalysis(getTheHexagonTarget(),
375 createHexagonMCInstrAnalysis);
376
Colin LeMahieube99a022015-06-17 03:06:16 +0000377 // Register the obj streamer
Krzysztof Parzyszek8cdfe8e2017-02-06 19:35:46 +0000378 TargetRegistry::RegisterELFStreamer(getTheHexagonTarget(),
379 createMCStreamer);
380
381 // Register the obj target streamer
382 TargetRegistry::RegisterObjectTargetStreamer(getTheHexagonTarget(),
383 createHexagonObjectTargetStreamer);
Colin LeMahieube99a022015-06-17 03:06:16 +0000384
Colin LeMahieud2158752015-06-18 20:43:50 +0000385 // Register the asm streamer
Mehdi Aminif42454b2016-10-09 23:00:34 +0000386 TargetRegistry::RegisterAsmTargetStreamer(getTheHexagonTarget(),
Colin LeMahieud2158752015-06-18 20:43:50 +0000387 createMCAsmTargetStreamer);
388
Sid Manning12cd21a2014-10-15 18:27:40 +0000389 // Register the MC Inst Printer
Mehdi Aminif42454b2016-10-09 23:00:34 +0000390 TargetRegistry::RegisterMCInstPrinter(getTheHexagonTarget(),
Sid Manning12cd21a2014-10-15 18:27:40 +0000391 createHexagonMCInstPrinter);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000392}