blob: c407e7cb1662786a9c01dbc71861dfc7118eba96 [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 LeMahieu7cd08922015-11-09 04:07:48 +000043cl::opt<bool> llvm::HexagonDisableCompound
44 ("mno-compound",
45 cl::desc("Disable looking for compound instructions for Hexagon"));
46
47cl::opt<bool> llvm::HexagonDisableDuplex
48 ("mno-pairing",
49 cl::desc("Disable looking for duplex instructions for Hexagon"));
50
Colin LeMahieuf08a3cc2015-02-19 17:38:39 +000051MCInstrInfo *llvm::createHexagonMCInstrInfo() {
Tony Linthicumb3705e02011-12-15 22:29:08 +000052 MCInstrInfo *X = new MCInstrInfo();
53 InitHexagonMCInstrInfo(X);
54 return X;
55}
56
Daniel Sanders50f17232015-09-15 16:17:27 +000057static MCRegisterInfo *createHexagonMCRegisterInfo(const Triple &TT) {
Tony Linthicumb3705e02011-12-15 22:29:08 +000058 MCRegisterInfo *X = new MCRegisterInfo();
59 InitHexagonMCRegisterInfo(X, Hexagon::R0);
60 return X;
61}
62
Daniel Sanders50f17232015-09-15 16:17:27 +000063static MCSubtargetInfo *
64createHexagonMCSubtargetInfo(const Triple &TT, StringRef CPU, StringRef FS) {
Colin LeMahieu7cd08922015-11-09 04:07:48 +000065 StringRef CPUName = CPU;
66 if (CPU.empty())
67 CPUName = "hexagonv5";
68 return createHexagonMCSubtargetInfoImpl(TT, CPUName, FS);
Tony Linthicumb3705e02011-12-15 22:29:08 +000069}
70
Colin LeMahieube99a022015-06-17 03:06:16 +000071namespace {
Colin LeMahieud2158752015-06-18 20:43:50 +000072class HexagonTargetAsmStreamer : public HexagonTargetStreamer {
Colin LeMahieud2158752015-06-18 20:43:50 +000073public:
74 HexagonTargetAsmStreamer(MCStreamer &S,
Colin LeMahieufa389722015-06-18 21:03:13 +000075 formatted_raw_ostream &, bool,
76 MCInstPrinter &)
77 : HexagonTargetStreamer(S) {}
Colin LeMahieud2158752015-06-18 20:43:50 +000078 void prettyPrintAsm(MCInstPrinter &InstPrinter, raw_ostream &OS,
79 const MCInst &Inst, const MCSubtargetInfo &STI) override {
80 assert(HexagonMCInstrInfo::isBundle(Inst));
81 assert(HexagonMCInstrInfo::bundleSize(Inst) <= HEXAGON_PACKET_SIZE);
82 std::string Buffer;
83 {
84 raw_string_ostream TempStream(Buffer);
85 InstPrinter.printInst(&Inst, TempStream, "", STI);
86 }
87 StringRef Contents(Buffer);
88 auto PacketBundle = Contents.rsplit('\n');
89 auto HeadTail = PacketBundle.first.split('\n');
90 auto Preamble = "\t{\n\t\t";
91 auto Separator = "";
92 while(!HeadTail.first.empty()) {
93 OS << Separator;
94 StringRef Inst;
95 auto Duplex = HeadTail.first.split('\v');
96 if(!Duplex.second.empty()){
97 OS << Duplex.first << "\n";
98 Inst = Duplex.second;
99 }
100 else {
101 if(!HeadTail.first.startswith("immext"))
102 Inst = Duplex.first;
103 }
104 OS << Preamble;
105 OS << Inst;
106 HeadTail = HeadTail.second.split('\n');
107 Preamble = "";
108 Separator = "\n\t\t";
109 }
110 if(HexagonMCInstrInfo::bundleSize(Inst) != 0)
111 OS << "\n\t}" << PacketBundle.second;
112 }
113};
Alexander Kornienkof00654e2015-06-23 09:49:53 +0000114}
Colin LeMahieud2158752015-06-18 20:43:50 +0000115
116namespace {
Colin LeMahieube99a022015-06-17 03:06:16 +0000117class HexagonTargetELFStreamer : public HexagonTargetStreamer {
118public:
119 MCELFStreamer &getStreamer() {
120 return static_cast<MCELFStreamer &>(Streamer);
121 }
122 HexagonTargetELFStreamer(MCStreamer &S, MCSubtargetInfo const &STI)
123 : HexagonTargetStreamer(S) {
124 auto Bits = STI.getFeatureBits();
125 unsigned Flags;
126 if (Bits.to_ullong() & llvm::Hexagon::ArchV5)
127 Flags = ELF::EF_HEXAGON_MACH_V5;
128 else
129 Flags = ELF::EF_HEXAGON_MACH_V4;
130 getStreamer().getAssembler().setELFHeaderEFlags(Flags);
131 }
132 void EmitCommonSymbolSorted(MCSymbol *Symbol, uint64_t Size,
133 unsigned ByteAlignment,
134 unsigned AccessSize) override {
135 HexagonMCELFStreamer &HexagonELFStreamer =
136 static_cast<HexagonMCELFStreamer &>(getStreamer());
137 HexagonELFStreamer.HexagonMCEmitCommonSymbol(Symbol, Size, ByteAlignment,
138 AccessSize);
139 }
140 void EmitLocalCommonSymbolSorted(MCSymbol *Symbol, uint64_t Size,
141 unsigned ByteAlignment,
142 unsigned AccessSize) override {
143 HexagonMCELFStreamer &HexagonELFStreamer =
144 static_cast<HexagonMCELFStreamer &>(getStreamer());
145 HexagonELFStreamer.HexagonMCEmitLocalCommonSymbol(
146 Symbol, Size, ByteAlignment, AccessSize);
147 }
148};
Alexander Kornienkof00654e2015-06-23 09:49:53 +0000149}
Colin LeMahieube99a022015-06-17 03:06:16 +0000150
Rafael Espindola227144c2013-05-13 01:16:13 +0000151static MCAsmInfo *createHexagonMCAsmInfo(const MCRegisterInfo &MRI,
Daniel Sanders50f17232015-09-15 16:17:27 +0000152 const Triple &TT) {
Rafael Espindola140a8372013-05-10 18:16:59 +0000153 MCAsmInfo *MAI = new HexagonMCAsmInfo(TT);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000154
155 // VirtualFP = (R30 + #0).
Sid Manning7da3f9a2014-10-03 13:18:11 +0000156 MCCFIInstruction Inst =
157 MCCFIInstruction::createDefCfa(nullptr, Hexagon::R30, 0);
Rafael Espindola227144c2013-05-13 01:16:13 +0000158 MAI->addInitialFrameState(Inst);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000159
160 return MAI;
161}
162
Daniel Sanders50f17232015-09-15 16:17:27 +0000163static MCCodeGenInfo *createHexagonMCCodeGenInfo(const Triple &TT,
Daniel Sandersf423f562015-07-06 16:56:07 +0000164 Reloc::Model RM,
Sid Manning7da3f9a2014-10-03 13:18:11 +0000165 CodeModel::Model CM,
166 CodeGenOpt::Level OL) {
Tony Linthicumb3705e02011-12-15 22:29:08 +0000167 MCCodeGenInfo *X = new MCCodeGenInfo();
168 // For the time being, use static relocations, since there's really no
169 // support for PIC yet.
Jim Grosbach4c98cf72015-05-15 19:13:31 +0000170 X->initMCCodeGenInfo(Reloc::Static, CM, OL);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000171 return X;
172}
Eric Christopherfbe80f52015-04-09 19:20:37 +0000173
Daniel Sanders50f17232015-09-15 16:17:27 +0000174static MCInstPrinter *createHexagonMCInstPrinter(const Triple &T,
Eric Christopherf8019402015-03-31 00:10:04 +0000175 unsigned SyntaxVariant,
Sid Manning12cd21a2014-10-15 18:27:40 +0000176 const MCAsmInfo &MAI,
177 const MCInstrInfo &MII,
Eric Christopherf8019402015-03-31 00:10:04 +0000178 const MCRegisterInfo &MRI) {
Eric Christopherfbe80f52015-04-09 19:20:37 +0000179 if (SyntaxVariant == 0)
Colin LeMahieube99a022015-06-17 03:06:16 +0000180 return (new HexagonInstPrinter(MAI, MII, MRI));
Eric Christopherfbe80f52015-04-09 19:20:37 +0000181 else
Colin LeMahieube99a022015-06-17 03:06:16 +0000182 return nullptr;
183}
184
Benjamin Kramere7800ca2015-06-23 14:51:40 +0000185static MCTargetStreamer *createMCAsmTargetStreamer(MCStreamer &S,
186 formatted_raw_ostream &OS,
187 MCInstPrinter *InstPrint,
188 bool IsVerboseAsm) {
Colin LeMahieud2158752015-06-18 20:43:50 +0000189 return new HexagonTargetAsmStreamer(S, OS, IsVerboseAsm, *InstPrint);
190}
191
Daniel Sanders50f17232015-09-15 16:17:27 +0000192static MCStreamer *createMCStreamer(Triple const &T, MCContext &Context,
Colin LeMahieube99a022015-06-17 03:06:16 +0000193 MCAsmBackend &MAB, raw_pwrite_stream &OS,
194 MCCodeEmitter *Emitter, bool RelaxAll) {
195 return createHexagonELFStreamer(Context, MAB, OS, Emitter);
196}
197
198static MCTargetStreamer *
199createHexagonObjectTargetStreamer(MCStreamer &S, MCSubtargetInfo const &STI) {
200 return new HexagonTargetELFStreamer(S, STI);
Sid Manning12cd21a2014-10-15 18:27:40 +0000201}
Tony Linthicumb3705e02011-12-15 22:29:08 +0000202
203// Force static initialization.
204extern "C" void LLVMInitializeHexagonTargetMC() {
205 // Register the MC asm info.
206 RegisterMCAsmInfoFn X(TheHexagonTarget, createHexagonMCAsmInfo);
207
208 // Register the MC codegen info.
209 TargetRegistry::RegisterMCCodeGenInfo(TheHexagonTarget,
210 createHexagonMCCodeGenInfo);
211
212 // Register the MC instruction info.
Sid Manning7da3f9a2014-10-03 13:18:11 +0000213 TargetRegistry::RegisterMCInstrInfo(TheHexagonTarget,
214 createHexagonMCInstrInfo);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000215
216 // Register the MC register info.
217 TargetRegistry::RegisterMCRegInfo(TheHexagonTarget,
218 createHexagonMCRegisterInfo);
219
220 // Register the MC subtarget info.
221 TargetRegistry::RegisterMCSubtargetInfo(TheHexagonTarget,
222 createHexagonMCSubtargetInfo);
Sid Manning7da3f9a2014-10-03 13:18:11 +0000223
224 // Register the MC Code Emitter
225 TargetRegistry::RegisterMCCodeEmitter(TheHexagonTarget,
226 createHexagonMCCodeEmitter);
Sid Manning12cd21a2014-10-15 18:27:40 +0000227
Colin LeMahieua6750772015-06-03 17:34:16 +0000228 // Register the asm backend
229 TargetRegistry::RegisterMCAsmBackend(TheHexagonTarget,
230 createHexagonAsmBackend);
231
Colin LeMahieube99a022015-06-17 03:06:16 +0000232 // Register the obj streamer
233 TargetRegistry::RegisterELFStreamer(TheHexagonTarget, createMCStreamer);
234
Colin LeMahieud2158752015-06-18 20:43:50 +0000235 // Register the asm streamer
236 TargetRegistry::RegisterAsmTargetStreamer(TheHexagonTarget,
237 createMCAsmTargetStreamer);
238
Sid Manning12cd21a2014-10-15 18:27:40 +0000239 // Register the MC Inst Printer
240 TargetRegistry::RegisterMCInstPrinter(TheHexagonTarget,
241 createHexagonMCInstPrinter);
Colin LeMahieube99a022015-06-17 03:06:16 +0000242
243 TargetRegistry::RegisterObjectTargetStreamer(
244 TheHexagonTarget, createHexagonObjectTargetStreamer);
Tony Linthicumb3705e02011-12-15 22:29:08 +0000245}