Coverage Report

Created: 2025-11-11 06:44

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/keystone/llvm/lib/Target/RISCV/MCTargetDesc/RISCVMCTargetDesc.cpp
Line
Count
Source
1
//===-- RISCVMCTargetDesc.cpp - RISCV Target Descriptions -----------------===//
2
//
3
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4
// See https://llvm.org/LICENSE.txt for license information.
5
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6
//
7
//===----------------------------------------------------------------------===//
8
///
9
/// This file provides RISCV-specific target descriptions.
10
///
11
//===----------------------------------------------------------------------===//
12
13
#include "RISCVMCTargetDesc.h"
14
#include "RISCVELFStreamer.h"
15
#include "RISCVMCAsmInfo.h"
16
#include "RISCVTargetStreamer.h"
17
#include "TargetInfo/RISCVTargetInfo.h"
18
#include "llvm/ADT/STLExtras.h"
19
#include "llvm/MC/MCAsmInfo.h"
20
#include "llvm/MC/MCInstrInfo.h"
21
#include "llvm/MC/MCRegisterInfo.h"
22
#include "llvm/MC/MCStreamer.h"
23
#include "llvm/MC/MCSubtargetInfo.h"
24
#include "llvm/Support/ErrorHandling.h"
25
#include "llvm/Support/TargetRegistry.h"
26
27
#define GET_INSTRINFO_MC_DESC
28
#include "RISCVGenInstrInfo.inc"
29
30
#define GET_REGINFO_MC_DESC
31
#include "RISCVGenRegisterInfo.inc"
32
33
#define GET_SUBTARGETINFO_MC_DESC
34
#include "RISCVGenSubtargetInfo.inc"
35
36
using namespace llvm_ks;
37
38
25.5k
static MCInstrInfo *createRISCVMCInstrInfo() {
39
25.5k
  MCInstrInfo *X = new MCInstrInfo();
40
25.5k
  InitRISCVMCInstrInfo(X);
41
25.5k
  return X;
42
25.5k
}
43
44
25.5k
static MCRegisterInfo *createRISCVMCRegisterInfo(const Triple &TT) {
45
25.5k
  MCRegisterInfo *X = new MCRegisterInfo();
46
25.5k
  InitRISCVMCRegisterInfo(X, RISCV::X1);
47
25.5k
  return X;
48
25.5k
}
49
50
static MCAsmInfo *createRISCVMCAsmInfo(const MCRegisterInfo &MRI,
51
25.5k
                                       const Triple &TT) {
52
25.5k
  MCAsmInfo *MAI = new RISCVMCAsmInfo(TT);
53
54
25.5k
  unsigned SP = MRI.getDwarfRegNum(RISCV::X2, true);
55
25.5k
  MCCFIInstruction Inst = MCCFIInstruction::createDefCfa(nullptr, SP, 0);
56
25.5k
  MAI->addInitialFrameState(Inst);
57
58
25.5k
  return MAI;
59
25.5k
}
60
61
static MCSubtargetInfo *createRISCVMCSubtargetInfo(const Triple &TT,
62
25.5k
                                                   StringRef CPU, StringRef FS) {
63
25.5k
  std::string CPUName = CPU;
64
25.5k
  if (CPUName.empty())
65
25.5k
    CPUName = TT.isArch64Bit() ? "generic-rv64" : "generic-rv32";
66
25.5k
  return createRISCVMCSubtargetInfoImpl(TT, CPUName, FS);
67
25.5k
}
68
69
70
static MCTargetStreamer *
71
25.5k
createRISCVObjectTargetStreamer(MCStreamer &S, const MCSubtargetInfo &STI) {
72
25.5k
  const Triple &TT = STI.getTargetTriple();
73
25.5k
  if (TT.isOSBinFormatELF())
74
25.5k
    return new RISCVTargetELFStreamer(S, STI);
75
0
  return nullptr;
76
25.5k
}
77
78
static MCTargetStreamer *createRISCVAsmTargetStreamer(MCStreamer &S,
79
0
                                                      formatted_raw_ostream &OS) {
80
0
  return new RISCVTargetAsmStreamer(S, OS);
81
0
}
82
83
26
extern "C" void LLVMInitializeRISCVTargetMC() {
84
52
  for (Target *T : {&TheRISCV32Target, &TheRISCV64Target}) {
85
52
    TargetRegistry::RegisterMCAsmInfo(*T, createRISCVMCAsmInfo);
86
52
    TargetRegistry::RegisterMCInstrInfo(*T, createRISCVMCInstrInfo);
87
52
    TargetRegistry::RegisterMCRegInfo(*T, createRISCVMCRegisterInfo);
88
    // TargetRegistry::RegisterMCAsmBackend(*T, createRISCVAsmBackend);
89
52
    TargetRegistry::RegisterMCAsmBackend2(*T, createRISCVAsmBackend);
90
52
    TargetRegistry::RegisterMCCodeEmitter(*T, createRISCVMCCodeEmitter);
91
52
    TargetRegistry::RegisterMCSubtargetInfo(*T, createRISCVMCSubtargetInfo);
92
52
    TargetRegistry::RegisterObjectTargetStreamer(
93
52
        *T, createRISCVObjectTargetStreamer);
94
95
    // Register the asm target streamer.
96
52
    TargetRegistry::RegisterAsmTargetStreamer(*T, createRISCVAsmTargetStreamer);
97
52
  }
98
26
}