1*fe6060f1SDimitry Andric //===------ riscv.cpp - Generic JITLink riscv edge kinds, utilities -------===// 2*fe6060f1SDimitry Andric // 3*fe6060f1SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4*fe6060f1SDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 5*fe6060f1SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6*fe6060f1SDimitry Andric // 7*fe6060f1SDimitry Andric //===----------------------------------------------------------------------===// 8*fe6060f1SDimitry Andric // 9*fe6060f1SDimitry Andric // Generic utilities for graphs representing riscv objects. 10*fe6060f1SDimitry Andric // 11*fe6060f1SDimitry Andric //===----------------------------------------------------------------------===// 12*fe6060f1SDimitry Andric 13*fe6060f1SDimitry Andric #include "llvm/ExecutionEngine/JITLink/riscv.h" 14*fe6060f1SDimitry Andric 15*fe6060f1SDimitry Andric #define DEBUG_TYPE "jitlink" 16*fe6060f1SDimitry Andric 17*fe6060f1SDimitry Andric namespace llvm { 18*fe6060f1SDimitry Andric namespace jitlink { 19*fe6060f1SDimitry Andric namespace riscv { 20*fe6060f1SDimitry Andric 21*fe6060f1SDimitry Andric const char *getEdgeKindName(Edge::Kind K) { 22*fe6060f1SDimitry Andric switch (K) { 23*fe6060f1SDimitry Andric case R_RISCV_32: 24*fe6060f1SDimitry Andric return "R_RISCV_32"; 25*fe6060f1SDimitry Andric case R_RISCV_64: 26*fe6060f1SDimitry Andric return "R_RISCV_64"; 27*fe6060f1SDimitry Andric case R_RISCV_HI20: 28*fe6060f1SDimitry Andric return "R_RISCV_HI20"; 29*fe6060f1SDimitry Andric case R_RISCV_LO12_I: 30*fe6060f1SDimitry Andric return "R_RISCV_LO12_I"; 31*fe6060f1SDimitry Andric case R_RISCV_PCREL_HI20: 32*fe6060f1SDimitry Andric return "R_RISCV_PCREL_HI20"; 33*fe6060f1SDimitry Andric case R_RISCV_PCREL_LO12_I: 34*fe6060f1SDimitry Andric return "R_RISCV_PCREL_LO12_I"; 35*fe6060f1SDimitry Andric case R_RISCV_PCREL_LO12_S: 36*fe6060f1SDimitry Andric return "R_RISCV_PCREL_LO12_S"; 37*fe6060f1SDimitry Andric case R_RISCV_CALL: 38*fe6060f1SDimitry Andric return "R_RISCV_CALL"; 39*fe6060f1SDimitry Andric } 40*fe6060f1SDimitry Andric return getGenericEdgeKindName(K); 41*fe6060f1SDimitry Andric } 42*fe6060f1SDimitry Andric } // namespace riscv 43*fe6060f1SDimitry Andric } // namespace jitlink 44*fe6060f1SDimitry Andric } // namespace llvm 45