blob: 2b35eab577bfaf8c37fe35210c5db9e033695106 [file] [log] [blame]
Alex Bradbury6b2cca72016-11-01 23:47:30 +00001//===-- 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"
Alex Bradbury2fee9ea2017-08-15 13:08:29 +000015#include "InstPrinter/RISCVInstPrinter.h"
Alex Bradbury4f7f0da2017-09-06 09:21:21 +000016#include "RISCVMCAsmInfo.h"
Alex Bradbury6b2cca72016-11-01 23:47:30 +000017#include "llvm/ADT/STLExtras.h"
18#include "llvm/MC/MCAsmInfo.h"
19#include "llvm/MC/MCInstrInfo.h"
20#include "llvm/MC/MCRegisterInfo.h"
21#include "llvm/MC/MCStreamer.h"
22#include "llvm/MC/MCSubtargetInfo.h"
23#include "llvm/Support/ErrorHandling.h"
24#include "llvm/Support/TargetRegistry.h"
25
26#define GET_INSTRINFO_MC_DESC
27#include "RISCVGenInstrInfo.inc"
28
29#define GET_REGINFO_MC_DESC
30#include "RISCVGenRegisterInfo.inc"
31
Alex Bradbury8ab4a962017-09-17 14:36:28 +000032#define GET_SUBTARGETINFO_MC_DESC
33#include "RISCVGenSubtargetInfo.inc"
34
Alex Bradbury6b2cca72016-11-01 23:47:30 +000035using namespace llvm;
36
37static MCInstrInfo *createRISCVMCInstrInfo() {
38 MCInstrInfo *X = new MCInstrInfo();
39 InitRISCVMCInstrInfo(X);
40 return X;
41}
42
43static MCRegisterInfo *createRISCVMCRegisterInfo(const Triple &TT) {
44 MCRegisterInfo *X = new MCRegisterInfo();
45 InitRISCVMCRegisterInfo(X, RISCV::X1_32);
46 return X;
47}
48
49static MCAsmInfo *createRISCVMCAsmInfo(const MCRegisterInfo &MRI,
50 const Triple &TT) {
Alex Bradburyd36e04c2017-02-14 05:15:24 +000051 return new RISCVMCAsmInfo(TT);
Alex Bradbury6b2cca72016-11-01 23:47:30 +000052}
53
Alex Bradbury2fee9ea2017-08-15 13:08:29 +000054static MCInstPrinter *createRISCVMCInstPrinter(const Triple &T,
55 unsigned SyntaxVariant,
56 const MCAsmInfo &MAI,
57 const MCInstrInfo &MII,
58 const MCRegisterInfo &MRI) {
59 return new RISCVInstPrinter(MAI, MII, MRI);
60}
61
Alex Bradbury6b2cca72016-11-01 23:47:30 +000062extern "C" void LLVMInitializeRISCVTargetMC() {
63 for (Target *T : {&getTheRISCV32Target(), &getTheRISCV64Target()}) {
Alex Bradburyd36e04c2017-02-14 05:15:24 +000064 TargetRegistry::RegisterMCAsmInfo(*T, createRISCVMCAsmInfo);
Alex Bradbury6b2cca72016-11-01 23:47:30 +000065 TargetRegistry::RegisterMCInstrInfo(*T, createRISCVMCInstrInfo);
66 TargetRegistry::RegisterMCRegInfo(*T, createRISCVMCRegisterInfo);
67 TargetRegistry::RegisterMCAsmBackend(*T, createRISCVAsmBackend);
68 TargetRegistry::RegisterMCCodeEmitter(*T, createRISCVMCCodeEmitter);
Alex Bradbury2fee9ea2017-08-15 13:08:29 +000069 TargetRegistry::RegisterMCInstPrinter(*T, createRISCVMCInstPrinter);
Alex Bradbury8ab4a962017-09-17 14:36:28 +000070 TargetRegistry::RegisterMCSubtargetInfo(*T, createRISCVMCSubtargetInfoImpl);
Alex Bradbury6b2cca72016-11-01 23:47:30 +000071 }
72}