1fe6060f1SDimitry Andric //===------ riscv.cpp - Generic JITLink riscv edge kinds, utilities -------===// 2fe6060f1SDimitry Andric // 3fe6060f1SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4fe6060f1SDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 5fe6060f1SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6fe6060f1SDimitry Andric // 7fe6060f1SDimitry Andric //===----------------------------------------------------------------------===// 8fe6060f1SDimitry Andric // 9fe6060f1SDimitry Andric // Generic utilities for graphs representing riscv objects. 10fe6060f1SDimitry Andric // 11fe6060f1SDimitry Andric //===----------------------------------------------------------------------===// 12fe6060f1SDimitry Andric 13fe6060f1SDimitry Andric #include "llvm/ExecutionEngine/JITLink/riscv.h" 14fe6060f1SDimitry Andric 15fe6060f1SDimitry Andric #define DEBUG_TYPE "jitlink" 16fe6060f1SDimitry Andric 17fe6060f1SDimitry Andric namespace llvm { 18fe6060f1SDimitry Andric namespace jitlink { 19fe6060f1SDimitry Andric namespace riscv { 20fe6060f1SDimitry Andric 21fe6060f1SDimitry Andric const char *getEdgeKindName(Edge::Kind K) { 22fe6060f1SDimitry Andric switch (K) { 23fe6060f1SDimitry Andric case R_RISCV_32: 24fe6060f1SDimitry Andric return "R_RISCV_32"; 25fe6060f1SDimitry Andric case R_RISCV_64: 26fe6060f1SDimitry Andric return "R_RISCV_64"; 2704eeddc0SDimitry Andric case R_RISCV_BRANCH: 2804eeddc0SDimitry Andric return "R_RISCV_BRANCH"; 29*81ad6265SDimitry Andric case R_RISCV_JAL: 30*81ad6265SDimitry Andric return "R_RISCV_JAL"; 31fe6060f1SDimitry Andric case R_RISCV_HI20: 32fe6060f1SDimitry Andric return "R_RISCV_HI20"; 33fe6060f1SDimitry Andric case R_RISCV_LO12_I: 34fe6060f1SDimitry Andric return "R_RISCV_LO12_I"; 35fe6060f1SDimitry Andric case R_RISCV_PCREL_HI20: 36fe6060f1SDimitry Andric return "R_RISCV_PCREL_HI20"; 37fe6060f1SDimitry Andric case R_RISCV_PCREL_LO12_I: 38fe6060f1SDimitry Andric return "R_RISCV_PCREL_LO12_I"; 39fe6060f1SDimitry Andric case R_RISCV_PCREL_LO12_S: 40fe6060f1SDimitry Andric return "R_RISCV_PCREL_LO12_S"; 41fe6060f1SDimitry Andric case R_RISCV_CALL: 42fe6060f1SDimitry Andric return "R_RISCV_CALL"; 4304eeddc0SDimitry Andric case R_RISCV_32_PCREL: 4404eeddc0SDimitry Andric return "R_RISCV_32_PCREL"; 4504eeddc0SDimitry Andric case R_RISCV_ADD64: 4604eeddc0SDimitry Andric return "R_RISCV_ADD64"; 4704eeddc0SDimitry Andric case R_RISCV_ADD32: 4804eeddc0SDimitry Andric return "R_RISCV_ADD32"; 4904eeddc0SDimitry Andric case R_RISCV_ADD16: 5004eeddc0SDimitry Andric return "R_RISCV_ADD16"; 5104eeddc0SDimitry Andric case R_RISCV_ADD8: 5204eeddc0SDimitry Andric return "R_RISCV_ADD8"; 5304eeddc0SDimitry Andric case R_RISCV_SUB64: 5404eeddc0SDimitry Andric return "R_RISCV_SUB64"; 5504eeddc0SDimitry Andric case R_RISCV_SUB32: 5604eeddc0SDimitry Andric return "R_RISCV_SUB32"; 5704eeddc0SDimitry Andric case R_RISCV_SUB16: 5804eeddc0SDimitry Andric return "R_RISCV_SUB16"; 5904eeddc0SDimitry Andric case R_RISCV_SUB8: 6004eeddc0SDimitry Andric return "R_RISCV_SUB8"; 61*81ad6265SDimitry Andric case R_RISCV_SUB6: 62*81ad6265SDimitry Andric return "R_RISCV_SUB6"; 6304eeddc0SDimitry Andric case R_RISCV_SET6: 6404eeddc0SDimitry Andric return "R_RISCV_SET6"; 6504eeddc0SDimitry Andric case R_RISCV_SET8: 6604eeddc0SDimitry Andric return "R_RISCV_SET8"; 6704eeddc0SDimitry Andric case R_RISCV_SET16: 6804eeddc0SDimitry Andric return "R_RISCV_SET16"; 6904eeddc0SDimitry Andric case R_RISCV_SET32: 7004eeddc0SDimitry Andric return "R_RISCV_SET32"; 71fe6060f1SDimitry Andric } 72fe6060f1SDimitry Andric return getGenericEdgeKindName(K); 73fe6060f1SDimitry Andric } 74fe6060f1SDimitry Andric } // namespace riscv 75fe6060f1SDimitry Andric } // namespace jitlink 76fe6060f1SDimitry Andric } // namespace llvm 77