xref: /freebsd-src/contrib/llvm-project/llvm/lib/Target/SPIRV/MCTargetDesc/SPIRVMCTargetDesc.cpp (revision 81ad626541db97eb356e2c1d4a20eb2a26a766ab)
1*81ad6265SDimitry Andric //===-- SPIRVMCTargetDesc.cpp - SPIR-V Target Descriptions ----*- C++ -*---===//
2*81ad6265SDimitry Andric //
3*81ad6265SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*81ad6265SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
5*81ad6265SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*81ad6265SDimitry Andric //
7*81ad6265SDimitry Andric //===----------------------------------------------------------------------===//
8*81ad6265SDimitry Andric //
9*81ad6265SDimitry Andric // This file provides SPIR-V specific target descriptions.
10*81ad6265SDimitry Andric //
11*81ad6265SDimitry Andric //===----------------------------------------------------------------------===//
12*81ad6265SDimitry Andric 
13*81ad6265SDimitry Andric #include "SPIRVMCTargetDesc.h"
14*81ad6265SDimitry Andric #include "SPIRVInstPrinter.h"
15*81ad6265SDimitry Andric #include "SPIRVMCAsmInfo.h"
16*81ad6265SDimitry Andric #include "SPIRVTargetStreamer.h"
17*81ad6265SDimitry Andric #include "TargetInfo/SPIRVTargetInfo.h"
18*81ad6265SDimitry Andric #include "llvm/MC/MCInstrAnalysis.h"
19*81ad6265SDimitry Andric #include "llvm/MC/MCInstrInfo.h"
20*81ad6265SDimitry Andric #include "llvm/MC/MCRegisterInfo.h"
21*81ad6265SDimitry Andric #include "llvm/MC/MCSubtargetInfo.h"
22*81ad6265SDimitry Andric #include "llvm/MC/TargetRegistry.h"
23*81ad6265SDimitry Andric 
24*81ad6265SDimitry Andric #define GET_INSTRINFO_MC_DESC
25*81ad6265SDimitry Andric #include "SPIRVGenInstrInfo.inc"
26*81ad6265SDimitry Andric 
27*81ad6265SDimitry Andric #define GET_SUBTARGETINFO_MC_DESC
28*81ad6265SDimitry Andric #include "SPIRVGenSubtargetInfo.inc"
29*81ad6265SDimitry Andric 
30*81ad6265SDimitry Andric #define GET_REGINFO_MC_DESC
31*81ad6265SDimitry Andric #include "SPIRVGenRegisterInfo.inc"
32*81ad6265SDimitry Andric 
33*81ad6265SDimitry Andric using namespace llvm;
34*81ad6265SDimitry Andric 
35*81ad6265SDimitry Andric static MCInstrInfo *createSPIRVMCInstrInfo() {
36*81ad6265SDimitry Andric   MCInstrInfo *X = new MCInstrInfo();
37*81ad6265SDimitry Andric   InitSPIRVMCInstrInfo(X);
38*81ad6265SDimitry Andric   return X;
39*81ad6265SDimitry Andric }
40*81ad6265SDimitry Andric 
41*81ad6265SDimitry Andric static MCRegisterInfo *createSPIRVMCRegisterInfo(const Triple &TT) {
42*81ad6265SDimitry Andric   MCRegisterInfo *X = new MCRegisterInfo();
43*81ad6265SDimitry Andric   return X;
44*81ad6265SDimitry Andric }
45*81ad6265SDimitry Andric 
46*81ad6265SDimitry Andric static MCSubtargetInfo *
47*81ad6265SDimitry Andric createSPIRVMCSubtargetInfo(const Triple &TT, StringRef CPU, StringRef FS) {
48*81ad6265SDimitry Andric   return createSPIRVMCSubtargetInfoImpl(TT, CPU, /*TuneCPU*/ CPU, FS);
49*81ad6265SDimitry Andric }
50*81ad6265SDimitry Andric 
51*81ad6265SDimitry Andric static MCStreamer *
52*81ad6265SDimitry Andric createSPIRVMCStreamer(const Triple &T, MCContext &Ctx,
53*81ad6265SDimitry Andric                       std::unique_ptr<MCAsmBackend> &&MAB,
54*81ad6265SDimitry Andric                       std::unique_ptr<MCObjectWriter> &&OW,
55*81ad6265SDimitry Andric                       std::unique_ptr<MCCodeEmitter> &&Emitter, bool RelaxAll) {
56*81ad6265SDimitry Andric   return createSPIRVStreamer(Ctx, std::move(MAB), std::move(OW),
57*81ad6265SDimitry Andric                              std::move(Emitter), RelaxAll);
58*81ad6265SDimitry Andric }
59*81ad6265SDimitry Andric 
60*81ad6265SDimitry Andric static MCTargetStreamer *createTargetAsmStreamer(MCStreamer &S,
61*81ad6265SDimitry Andric                                                  formatted_raw_ostream &,
62*81ad6265SDimitry Andric                                                  MCInstPrinter *, bool) {
63*81ad6265SDimitry Andric   return new SPIRVTargetStreamer(S);
64*81ad6265SDimitry Andric }
65*81ad6265SDimitry Andric 
66*81ad6265SDimitry Andric static MCInstPrinter *createSPIRVMCInstPrinter(const Triple &T,
67*81ad6265SDimitry Andric                                                unsigned SyntaxVariant,
68*81ad6265SDimitry Andric                                                const MCAsmInfo &MAI,
69*81ad6265SDimitry Andric                                                const MCInstrInfo &MII,
70*81ad6265SDimitry Andric                                                const MCRegisterInfo &MRI) {
71*81ad6265SDimitry Andric   assert(SyntaxVariant == 0);
72*81ad6265SDimitry Andric   return new SPIRVInstPrinter(MAI, MII, MRI);
73*81ad6265SDimitry Andric }
74*81ad6265SDimitry Andric 
75*81ad6265SDimitry Andric namespace {
76*81ad6265SDimitry Andric 
77*81ad6265SDimitry Andric class SPIRVMCInstrAnalysis : public MCInstrAnalysis {
78*81ad6265SDimitry Andric public:
79*81ad6265SDimitry Andric   explicit SPIRVMCInstrAnalysis(const MCInstrInfo *Info)
80*81ad6265SDimitry Andric       : MCInstrAnalysis(Info) {}
81*81ad6265SDimitry Andric };
82*81ad6265SDimitry Andric 
83*81ad6265SDimitry Andric } // end anonymous namespace
84*81ad6265SDimitry Andric 
85*81ad6265SDimitry Andric static MCInstrAnalysis *createSPIRVInstrAnalysis(const MCInstrInfo *Info) {
86*81ad6265SDimitry Andric   return new SPIRVMCInstrAnalysis(Info);
87*81ad6265SDimitry Andric }
88*81ad6265SDimitry Andric 
89*81ad6265SDimitry Andric extern "C" LLVM_EXTERNAL_VISIBILITY void LLVMInitializeSPIRVTargetMC() {
90*81ad6265SDimitry Andric   for (Target *T : {&getTheSPIRV32Target(), &getTheSPIRV64Target()}) {
91*81ad6265SDimitry Andric     RegisterMCAsmInfo<SPIRVMCAsmInfo> X(*T);
92*81ad6265SDimitry Andric     TargetRegistry::RegisterMCInstrInfo(*T, createSPIRVMCInstrInfo);
93*81ad6265SDimitry Andric     TargetRegistry::RegisterMCRegInfo(*T, createSPIRVMCRegisterInfo);
94*81ad6265SDimitry Andric     TargetRegistry::RegisterMCSubtargetInfo(*T, createSPIRVMCSubtargetInfo);
95*81ad6265SDimitry Andric     TargetRegistry::RegisterSPIRVStreamer(*T, createSPIRVMCStreamer);
96*81ad6265SDimitry Andric     TargetRegistry::RegisterMCInstPrinter(*T, createSPIRVMCInstPrinter);
97*81ad6265SDimitry Andric     TargetRegistry::RegisterMCInstrAnalysis(*T, createSPIRVInstrAnalysis);
98*81ad6265SDimitry Andric     TargetRegistry::RegisterMCCodeEmitter(*T, createSPIRVMCCodeEmitter);
99*81ad6265SDimitry Andric     TargetRegistry::RegisterMCAsmBackend(*T, createSPIRVAsmBackend);
100*81ad6265SDimitry Andric     TargetRegistry::RegisterAsmTargetStreamer(*T, createTargetAsmStreamer);
101*81ad6265SDimitry Andric   }
102*81ad6265SDimitry Andric }
103