Path: blob/main/contrib/llvm-project/llvm/lib/Target/SPIRV/MCTargetDesc/SPIRVMCTargetDesc.cpp
35294 views
//===-- SPIRVMCTargetDesc.cpp - SPIR-V Target Descriptions ----*- C++ -*---===//1//2// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.3// See https://llvm.org/LICENSE.txt for license information.4// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception5//6//===----------------------------------------------------------------------===//7//8// This file provides SPIR-V specific target descriptions.9//10//===----------------------------------------------------------------------===//1112#include "SPIRVMCTargetDesc.h"13#include "SPIRVInstPrinter.h"14#include "SPIRVMCAsmInfo.h"15#include "SPIRVTargetStreamer.h"16#include "TargetInfo/SPIRVTargetInfo.h"17#include "llvm/MC/MCInstrAnalysis.h"18#include "llvm/MC/MCInstrInfo.h"19#include "llvm/MC/MCRegisterInfo.h"20#include "llvm/MC/MCSubtargetInfo.h"21#include "llvm/MC/TargetRegistry.h"2223#define GET_INSTRINFO_MC_DESC24#define ENABLE_INSTR_PREDICATE_VERIFIER25#include "SPIRVGenInstrInfo.inc"2627#define GET_SUBTARGETINFO_MC_DESC28#include "SPIRVGenSubtargetInfo.inc"2930#define GET_REGINFO_MC_DESC31#include "SPIRVGenRegisterInfo.inc"3233using namespace llvm;3435static MCInstrInfo *createSPIRVMCInstrInfo() {36MCInstrInfo *X = new MCInstrInfo();37InitSPIRVMCInstrInfo(X);38return X;39}4041static MCRegisterInfo *createSPIRVMCRegisterInfo(const Triple &TT) {42MCRegisterInfo *X = new MCRegisterInfo();43return X;44}4546static MCSubtargetInfo *47createSPIRVMCSubtargetInfo(const Triple &TT, StringRef CPU, StringRef FS) {48return createSPIRVMCSubtargetInfoImpl(TT, CPU, /*TuneCPU*/ CPU, FS);49}5051static MCTargetStreamer *createTargetAsmStreamer(MCStreamer &S,52formatted_raw_ostream &,53MCInstPrinter *) {54return new SPIRVTargetStreamer(S);55}5657static MCInstPrinter *createSPIRVMCInstPrinter(const Triple &T,58unsigned SyntaxVariant,59const MCAsmInfo &MAI,60const MCInstrInfo &MII,61const MCRegisterInfo &MRI) {62assert(SyntaxVariant == 0);63return new SPIRVInstPrinter(MAI, MII, MRI);64}6566namespace {6768class SPIRVMCInstrAnalysis : public MCInstrAnalysis {69public:70explicit SPIRVMCInstrAnalysis(const MCInstrInfo *Info)71: MCInstrAnalysis(Info) {}72};7374} // end anonymous namespace7576static MCInstrAnalysis *createSPIRVInstrAnalysis(const MCInstrInfo *Info) {77return new SPIRVMCInstrAnalysis(Info);78}7980extern "C" LLVM_EXTERNAL_VISIBILITY void LLVMInitializeSPIRVTargetMC() {81for (Target *T : {&getTheSPIRV32Target(), &getTheSPIRV64Target(),82&getTheSPIRVLogicalTarget()}) {83RegisterMCAsmInfo<SPIRVMCAsmInfo> X(*T);84TargetRegistry::RegisterMCInstrInfo(*T, createSPIRVMCInstrInfo);85TargetRegistry::RegisterMCRegInfo(*T, createSPIRVMCRegisterInfo);86TargetRegistry::RegisterMCSubtargetInfo(*T, createSPIRVMCSubtargetInfo);87TargetRegistry::RegisterMCInstPrinter(*T, createSPIRVMCInstPrinter);88TargetRegistry::RegisterMCInstrAnalysis(*T, createSPIRVInstrAnalysis);89TargetRegistry::RegisterMCCodeEmitter(*T, createSPIRVMCCodeEmitter);90TargetRegistry::RegisterMCAsmBackend(*T, createSPIRVAsmBackend);91TargetRegistry::RegisterAsmTargetStreamer(*T, createTargetAsmStreamer);92}93}949596