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 getEdgeKindName(Edge::Kind K)21fe6060f1SDimitry Andricconst 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"; 2981ad6265SDimitry Andric case R_RISCV_JAL: 3081ad6265SDimitry Andric return "R_RISCV_JAL"; 31bdd1243dSDimitry Andric case R_RISCV_CALL: 32bdd1243dSDimitry Andric return "R_RISCV_CALL"; 33bdd1243dSDimitry Andric case R_RISCV_CALL_PLT: 34bdd1243dSDimitry Andric return "R_RISCV_CALL_PLT"; 35bdd1243dSDimitry Andric case R_RISCV_GOT_HI20: 36bdd1243dSDimitry Andric return "R_RISCV_GOT_HI20"; 37fe6060f1SDimitry Andric case R_RISCV_PCREL_HI20: 38fe6060f1SDimitry Andric return "R_RISCV_PCREL_HI20"; 39fe6060f1SDimitry Andric case R_RISCV_PCREL_LO12_I: 40fe6060f1SDimitry Andric return "R_RISCV_PCREL_LO12_I"; 41fe6060f1SDimitry Andric case R_RISCV_PCREL_LO12_S: 42fe6060f1SDimitry Andric return "R_RISCV_PCREL_LO12_S"; 43bdd1243dSDimitry Andric case R_RISCV_HI20: 44bdd1243dSDimitry Andric return "R_RISCV_HI20"; 45bdd1243dSDimitry Andric case R_RISCV_LO12_I: 46bdd1243dSDimitry Andric return "R_RISCV_LO12_I"; 47bdd1243dSDimitry Andric case R_RISCV_LO12_S: 48bdd1243dSDimitry Andric return "R_RISCV_LO12_S"; 4904eeddc0SDimitry Andric case R_RISCV_ADD8: 5004eeddc0SDimitry Andric return "R_RISCV_ADD8"; 51bdd1243dSDimitry Andric case R_RISCV_ADD16: 52bdd1243dSDimitry Andric return "R_RISCV_ADD16"; 53bdd1243dSDimitry Andric case R_RISCV_ADD32: 54bdd1243dSDimitry Andric return "R_RISCV_ADD32"; 55bdd1243dSDimitry Andric case R_RISCV_ADD64: 56bdd1243dSDimitry Andric return "R_RISCV_ADD64"; 5704eeddc0SDimitry Andric case R_RISCV_SUB8: 5804eeddc0SDimitry Andric return "R_RISCV_SUB8"; 59bdd1243dSDimitry Andric case R_RISCV_SUB16: 60bdd1243dSDimitry Andric return "R_RISCV_SUB16"; 61bdd1243dSDimitry Andric case R_RISCV_SUB32: 62bdd1243dSDimitry Andric return "R_RISCV_SUB32"; 63bdd1243dSDimitry Andric case R_RISCV_SUB64: 64bdd1243dSDimitry Andric return "R_RISCV_SUB64"; 65bdd1243dSDimitry Andric case R_RISCV_RVC_BRANCH: 66bdd1243dSDimitry Andric return "R_RISCV_RVC_BRANCH"; 67bdd1243dSDimitry Andric case R_RISCV_RVC_JUMP: 68bdd1243dSDimitry Andric return "R_RISCV_RVC_JUMP"; 6981ad6265SDimitry Andric case R_RISCV_SUB6: 7081ad6265SDimitry Andric return "R_RISCV_SUB6"; 7104eeddc0SDimitry Andric case R_RISCV_SET6: 7204eeddc0SDimitry Andric return "R_RISCV_SET6"; 7304eeddc0SDimitry Andric case R_RISCV_SET8: 7404eeddc0SDimitry Andric return "R_RISCV_SET8"; 7504eeddc0SDimitry Andric case R_RISCV_SET16: 7604eeddc0SDimitry Andric return "R_RISCV_SET16"; 7704eeddc0SDimitry Andric case R_RISCV_SET32: 7804eeddc0SDimitry Andric return "R_RISCV_SET32"; 79bdd1243dSDimitry Andric case R_RISCV_32_PCREL: 80bdd1243dSDimitry Andric return "R_RISCV_32_PCREL"; 8106c3fb27SDimitry Andric case CallRelaxable: 8206c3fb27SDimitry Andric return "CallRelaxable"; 8306c3fb27SDimitry Andric case AlignRelaxable: 8406c3fb27SDimitry Andric return "AlignRelaxable"; 85*5f757f3fSDimitry Andric case NegDelta32: 86*5f757f3fSDimitry Andric return "NegDelta32"; 87fe6060f1SDimitry Andric } 88fe6060f1SDimitry Andric return getGenericEdgeKindName(K); 89fe6060f1SDimitry Andric } 90fe6060f1SDimitry Andric } // namespace riscv 91fe6060f1SDimitry Andric } // namespace jitlink 92fe6060f1SDimitry Andric } // namespace llvm 93