blob: bf6fb14dcca5088e270780da97da51d72089eb3a [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
Colin LeMahieud2158752015-06-18 20:43:50 +000014#include "HexagonMCTargetDesc.h"
15#include "Hexagon.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000016#include "HexagonMCAsmInfo.h"
Colin LeMahieube99a022015-06-17 03:06:16 +000017#include "HexagonMCELFStreamer.h"
Colin LeMahieuff062612014-11-20 21:56:35 +000018#include "MCTargetDesc/HexagonInstPrinter.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000019#include "llvm/MC/MCCodeGenInfo.h"
Colin LeMahieube99a022015-06-17 03:06:16 +000020#include "llvm/MC/MCContext.h"
Colin LeMahieu2c769202014-11-06 17:05:51 +000021#include "llvm/MC/MCELFStreamer.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000022#include "llvm/MC/MCInstrInfo.h"
Colin LeMahieube99a022015-06-17 03:06:16 +000023#include "llvm/MC/MCObjectStreamer.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000024#include "llvm/MC/MCRegisterInfo.h"
Jyotsna Verma7503a622013-02-20 16:13:27 +000025#include "llvm/MC/MCStreamer.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000026#include "llvm/MC/MCSubtargetInfo.h"
Chandler Carruth8a8cd2b2014-01-07 11:48:04 +000027#include "llvm/MC/MachineLocation.h"
Colin LeMahieube99a022015-06-17 03:06:16 +000028#include "llvm/Support/ELF.h"
Craig Topperc4965bc2012-02-05 07:21:30 +000029#include "llvm/Support/ErrorHandling.h"
Tony Linthicumb3705e02011-12-15 22:29:08 +000030#include "llvm/Support/TargetRegistry.h"
31
Chandler Carruthd174b722014-04-22 02:03:14 +000032using namespace llvm;
33
Tony Linthicumb3705e02011-12-15 22:29:08 +000034#define GET_INSTRINFO_MC_DESC
35#include "HexagonGenInstrInfo.inc"
36
37#define GET_SUBTARGETINFO_MC_DESC
38#include "HexagonGenSubtargetInfo.inc"
39
40#define GET_REGINFO_MC_DESC
41#include "HexagonGenRegisterInfo.inc"
42
Colin LeMahieuf08a3cc2015-02-19 17:38:39 +000043MCInstrInfo *llvm::createHexagonMCInstrInfo() {
Tony Linthicumb3705e02011-12-15 22:29:08 +000044 MCInstrInfo *X = new MCInstrInfo();
45 InitHexagonMCInstrInfo(X);
46 return X;
47}
48
49static MCRegisterInfo *createHexagonMCRegisterInfo(StringRef TT) {
50 MCRegisterInfo *X = new MCRegisterInfo();
51 InitHexagonMCRegisterInfo(X, Hexagon::R0);
52 return X;
53}
54
Sid Manning7da3f9a2014-10-03 13:18:11 +000055static MCSubtargetInfo *
Daniel Sandersa73f1fd2015-06-10 12:11:26 +000056createHexagonMCSubtargetInfo(const Triple &TT, StringRef CPU, StringRef FS) {
Tony Linthicumb3705e02011-12-15 22:29:08 +000057 MCSubtargetInfo *X = new MCSubtargetInfo();
58 InitHexagonMCSubtargetInfo(X, TT, CPU, FS);
59 return X;
60}
61
Colin LeMahieube99a022015-06-17 03:06:16 +000062namespace {
Colin LeMahieud2158752015-06-18 20:43:50 +000063class HexagonTargetAsmStreamer : public HexagonTargetStreamer {
64 MCContext &Ctx;
65 formatted_raw_ostream &OS;
66 bool isVerboseAsm;
67 MCInstPrinter &IP;
68public:
69 HexagonTargetAsmStreamer(MCStreamer &S,
70 formatted_raw_ostream &OS, bool isVerboseAsm,
71 MCInstPrinter &IP)
72 : HexagonTargetStreamer(S), Ctx(Ctx), OS(OS), isVerboseAsm(isVerboseAsm),
73 IP(IP) {}
74 MCStreamer &getStreamer() { return Streamer; }
75 void prettyPrintAsm(MCInstPrinter &InstPrinter, raw_ostream &OS,
76 const MCInst &Inst, const MCSubtargetInfo &STI) override {
77 assert(HexagonMCInstrInfo::isBundle(Inst));
78 assert(HexagonMCInstrInfo::bundleSize(Inst) <= HEXAGON_PACKET_SIZE);
79 std::string Buffer;
80 {
81 raw_string_ostream TempStream(Buffer);
82 InstPrinter.printInst(&Inst, TempStream, "", STI);
83 }
84 StringRef Contents(Buffer);
85 auto PacketBundle = Contents.rsplit('\n');
86 auto HeadTail = PacketBundle.first.split('\n');
87 auto Preamble = "\t{\n\t\t";
88 auto Separator = "";
89 while(!HeadTail.first.empty()) {
90 OS << Separator;
91 StringRef Inst;
92 auto Duplex = HeadTail.first.split('\v');
93 if(!Duplex.second.empty()){
94 OS << Duplex.first << "\n";
95 Inst = Duplex.second;
96 }
97 else {
98 if(!HeadTail.first.startswith("immext"))
99 Inst = Duplex.first;
100 }
101 OS << Preamble;
102 OS << Inst;
103 HeadTail = HeadTail.second.split('\n');
104 Preamble = "";
105 Separator = "\n\t\t";
106 }
107 if(HexagonMCInstrInfo::bundleSize(Inst) != 0)
108 OS << "\n\t}" << PacketBundle.second;
109 }
110};
111}
112
113namespace {
Colin LeMahieube99a022015-06-17 03:06:16 +0000114class HexagonTargetELFStreamer : public HexagonTargetStreamer {
115public:
116 MCELFStreamer &getStreamer() {
117 return static_cast<MCELFStreamer &>(Streamer);
118 }
119 HexagonTargetELFStreamer(MCStreamer &S, MCSubtargetInfo const &STI)
120 : HexagonTargetStreamer(S) {
121 auto Bits = STI.getFeatureBits();
122 unsigned Flags;
123 if (Bits.to_ullong() & llvm::Hexagon::ArchV5)
124 Flags = ELF::EF_HEXAGON_MACH_V5;
125 else
126 Flags = ELF::EF_HEXAGON_MACH_V4;
127 getStreamer().getAssembler().setELFHeaderEFlags(Flags);
128 }
129 void EmitCommonSymbolSorted(MCSymbol *Symbol, uint64_t Size,
130 unsigned ByteAlignment,
131 unsigned AccessSize) override {
132 HexagonMCELFStreamer &HexagonELFStreamer =
133 static_cast<HexagonMCELFStreamer &>(getStreamer());
134 HexagonELFStreamer.HexagonMCEmitCommonSymbol(Symbol, Size, ByteAlignment,
135 AccessSize);
136 }
137 void EmitLocalCommonSymbolSorted(MCSymbol *Symbol, uint64_t Size,
138 unsigned ByteAlignment,
139 unsigned AccessSize) override {
140 HexagonMCELFStreamer &HexagonELFStreamer =
141 static_cast<HexagonMCELFStreamer &>(getStreamer());
142 HexagonELFStreamer.HexagonMCEmitLocalCommonSymbol(
143 Symbol, Size, ByteAlignment, AccessSize);
144 }
145};
146}
147
Rafael Espindola227144c2013-05-13 01:16:13 +0000148static MCAsmInfo *createHexagonMCAsmInfo(const MCRegisterInfo &MRI,
Daniel Sanders7813ae82015-06-04 13:12:25 +0000149 const Triple &TT) {
Rafael Espindola140a8372013-05-10 18:16:59 +0000150 MCAsmInfo *MAI = new HexagonMCAsmInfo(TT);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000151
152 // VirtualFP = (R30 + #0).
Sid Manning7da3f9a2014-10-03 13:18:11 +0000153 MCCFIInstruction Inst =
154 MCCFIInstruction::createDefCfa(nullptr, Hexagon::R30, 0);
Rafael Espindola227144c2013-05-13 01:16:13 +0000155 MAI->addInitialFrameState(Inst);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000156
157 return MAI;
158}
159
160static MCCodeGenInfo *createHexagonMCCodeGenInfo(StringRef TT, Reloc::Model RM,
Sid Manning7da3f9a2014-10-03 13:18:11 +0000161 CodeModel::Model CM,
162 CodeGenOpt::Level OL) {
Tony Linthicumb3705e02011-12-15 22:29:08 +0000163 MCCodeGenInfo *X = new MCCodeGenInfo();
164 // For the time being, use static relocations, since there's really no
165 // support for PIC yet.
Jim Grosbach4c98cf72015-05-15 19:13:31 +0000166 X->initMCCodeGenInfo(Reloc::Static, CM, OL);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000167 return X;
168}
Eric Christopherfbe80f52015-04-09 19:20:37 +0000169
Eric Christopherf8019402015-03-31 00:10:04 +0000170static MCInstPrinter *createHexagonMCInstPrinter(const Triple &T,
171 unsigned SyntaxVariant,
Sid Manning12cd21a2014-10-15 18:27:40 +0000172 const MCAsmInfo &MAI,
173 const MCInstrInfo &MII,
Eric Christopherf8019402015-03-31 00:10:04 +0000174 const MCRegisterInfo &MRI) {
Eric Christopherfbe80f52015-04-09 19:20:37 +0000175 if (SyntaxVariant == 0)
Colin LeMahieube99a022015-06-17 03:06:16 +0000176 return (new HexagonInstPrinter(MAI, MII, MRI));
Eric Christopherfbe80f52015-04-09 19:20:37 +0000177 else
Colin LeMahieube99a022015-06-17 03:06:16 +0000178 return nullptr;
179}
180
Colin LeMahieud2158752015-06-18 20:43:50 +0000181MCTargetStreamer *createMCAsmTargetStreamer(
182 MCStreamer &S, formatted_raw_ostream &OS, MCInstPrinter *InstPrint,
183 bool IsVerboseAsm) {
184 return new HexagonTargetAsmStreamer(S, OS, IsVerboseAsm, *InstPrint);
185}
186
Colin LeMahieube99a022015-06-17 03:06:16 +0000187static MCStreamer *createMCStreamer(Triple const &T, MCContext &Context,
188 MCAsmBackend &MAB, raw_pwrite_stream &OS,
189 MCCodeEmitter *Emitter, bool RelaxAll) {
190 return createHexagonELFStreamer(Context, MAB, OS, Emitter);
191}
192
193static MCTargetStreamer *
194createHexagonObjectTargetStreamer(MCStreamer &S, MCSubtargetInfo const &STI) {
195 return new HexagonTargetELFStreamer(S, STI);
Sid Manning12cd21a2014-10-15 18:27:40 +0000196}
Tony Linthicumb3705e02011-12-15 22:29:08 +0000197
198// Force static initialization.
199extern "C" void LLVMInitializeHexagonTargetMC() {
200 // Register the MC asm info.
201 RegisterMCAsmInfoFn X(TheHexagonTarget, createHexagonMCAsmInfo);
202
203 // Register the MC codegen info.
204 TargetRegistry::RegisterMCCodeGenInfo(TheHexagonTarget,
205 createHexagonMCCodeGenInfo);
206
207 // Register the MC instruction info.
Sid Manning7da3f9a2014-10-03 13:18:11 +0000208 TargetRegistry::RegisterMCInstrInfo(TheHexagonTarget,
209 createHexagonMCInstrInfo);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000210
211 // Register the MC register info.
212 TargetRegistry::RegisterMCRegInfo(TheHexagonTarget,
213 createHexagonMCRegisterInfo);
214
215 // Register the MC subtarget info.
216 TargetRegistry::RegisterMCSubtargetInfo(TheHexagonTarget,
217 createHexagonMCSubtargetInfo);
Sid Manning7da3f9a2014-10-03 13:18:11 +0000218
219 // Register the MC Code Emitter
220 TargetRegistry::RegisterMCCodeEmitter(TheHexagonTarget,
221 createHexagonMCCodeEmitter);
Sid Manning12cd21a2014-10-15 18:27:40 +0000222
Colin LeMahieua6750772015-06-03 17:34:16 +0000223 // Register the asm backend
224 TargetRegistry::RegisterMCAsmBackend(TheHexagonTarget,
225 createHexagonAsmBackend);
226
Colin LeMahieube99a022015-06-17 03:06:16 +0000227 // Register the obj streamer
228 TargetRegistry::RegisterELFStreamer(TheHexagonTarget, createMCStreamer);
229
Colin LeMahieud2158752015-06-18 20:43:50 +0000230 // Register the asm streamer
231 TargetRegistry::RegisterAsmTargetStreamer(TheHexagonTarget,
232 createMCAsmTargetStreamer);
233
Sid Manning12cd21a2014-10-15 18:27:40 +0000234 // Register the MC Inst Printer
235 TargetRegistry::RegisterMCInstPrinter(TheHexagonTarget,
236 createHexagonMCInstPrinter);
Colin LeMahieube99a022015-06-17 03:06:16 +0000237
238 TargetRegistry::RegisterObjectTargetStreamer(
239 TheHexagonTarget, createHexagonObjectTargetStreamer);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000240}