RISCVMCTargetDesc.cpp revision 321369
1//===-- RISCVMCTargetDesc.cpp - RISCV Target Descriptions -----------------===// 2// 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/// 10/// This file provides RISCV-specific target descriptions. 11/// 12//===----------------------------------------------------------------------===// 13 14#include "RISCVMCTargetDesc.h" 15#include "RISCVMCAsmInfo.h" 16#include "llvm/ADT/STLExtras.h" 17#include "llvm/MC/MCAsmInfo.h" 18#include "llvm/MC/MCInstrInfo.h" 19#include "llvm/MC/MCRegisterInfo.h" 20#include "llvm/MC/MCStreamer.h" 21#include "llvm/MC/MCSubtargetInfo.h" 22#include "llvm/Support/ErrorHandling.h" 23#include "llvm/Support/TargetRegistry.h" 24 25#define GET_INSTRINFO_MC_DESC 26#include "RISCVGenInstrInfo.inc" 27 28#define GET_REGINFO_MC_DESC 29#include "RISCVGenRegisterInfo.inc" 30 31using namespace llvm; 32 33static MCInstrInfo *createRISCVMCInstrInfo() { 34 MCInstrInfo *X = new MCInstrInfo(); 35 InitRISCVMCInstrInfo(X); 36 return X; 37} 38 39static MCRegisterInfo *createRISCVMCRegisterInfo(const Triple &TT) { 40 MCRegisterInfo *X = new MCRegisterInfo(); 41 InitRISCVMCRegisterInfo(X, RISCV::X1_32); 42 return X; 43} 44 45static MCAsmInfo *createRISCVMCAsmInfo(const MCRegisterInfo &MRI, 46 const Triple &TT) { 47 return new RISCVMCAsmInfo(TT); 48} 49 50extern "C" void LLVMInitializeRISCVTargetMC() { 51 for (Target *T : {&getTheRISCV32Target(), &getTheRISCV64Target()}) { 52 TargetRegistry::RegisterMCAsmInfo(*T, createRISCVMCAsmInfo); 53 TargetRegistry::RegisterMCInstrInfo(*T, createRISCVMCInstrInfo); 54 TargetRegistry::RegisterMCRegInfo(*T, createRISCVMCRegisterInfo); 55 TargetRegistry::RegisterMCAsmBackend(*T, createRISCVAsmBackend); 56 TargetRegistry::RegisterMCCodeEmitter(*T, createRISCVMCCodeEmitter); 57 } 58} 59