1 //===-- RISCVTargetInfo.cpp - RISCV Target Implementation -----------------===//
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 #include "TargetInfo/RISCVTargetInfo.h"
10 #include "llvm/MC/TargetRegistry.h"
11 using namespace llvm;
12 
13 Target &llvm::getTheRISCV32Target() {
14   static Target TheRISCV32Target;
15   return TheRISCV32Target;
16 }
17 
18 Target &llvm::getTheRISCV64Target() {
19   static Target TheRISCV64Target;
20   return TheRISCV64Target;
21 }
22 
23 extern "C" LLVM_EXTERNAL_VISIBILITY void LLVMInitializeRISCVTargetInfo() {
24   RegisterTarget<Triple::riscv32> X(getTheRISCV32Target(), "riscv32",
25                                     "32-bit RISC-V", "RISCV");
26   RegisterTarget<Triple::riscv64> Y(getTheRISCV64Target(), "riscv64",
27                                     "64-bit RISC-V", "RISCV");
28 }
29