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