clang 20.0.0 (based on r547379) from build 12806354. Bug: http://b/379133546 Test: N/A Change-Id: I2eb8938af55d809de674be63cb30cf27e801862b Upstream-Commit: ad834e67b1105d15ef907f6255d4c96e8e733f57
233 lines
5.5 KiB
C++
233 lines
5.5 KiB
C++
//===-- riscv.h - Generic JITLink riscv edge kinds, utilities -*- C++ -*-===//
|
|
//
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// Generic utilities for graphs representing riscv objects.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_EXECUTIONENGINE_JITLINK_RISCV_H
|
|
#define LLVM_EXECUTIONENGINE_JITLINK_RISCV_H
|
|
|
|
#include "llvm/ExecutionEngine/JITLink/JITLink.h"
|
|
|
|
namespace llvm {
|
|
namespace jitlink {
|
|
namespace riscv {
|
|
|
|
/// Represents riscv fixups. Ordered in the same way as the relocations in
|
|
/// include/llvm/BinaryFormat/ELFRelocs/RISCV.def.
|
|
enum EdgeKind_riscv : Edge::Kind {
|
|
|
|
// TODO: Capture and replace to generic fixups
|
|
/// A plain 32-bit pointer value relocation
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <= Target + Addend : uint32
|
|
///
|
|
R_RISCV_32 = Edge::FirstRelocation,
|
|
|
|
/// A plain 64-bit pointer value relocation
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- Target + Addend : uint32
|
|
///
|
|
R_RISCV_64,
|
|
|
|
/// PC-relative branch pointer value relocation
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend)
|
|
///
|
|
R_RISCV_BRANCH,
|
|
|
|
/// High 20 bits of PC-relative jump pointer value relocation
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- Target - Fixup + Addend
|
|
///
|
|
R_RISCV_JAL,
|
|
|
|
/// PC relative call
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend)
|
|
R_RISCV_CALL,
|
|
|
|
/// PC relative call by PLT
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend)
|
|
R_RISCV_CALL_PLT,
|
|
|
|
/// PC relative GOT offset
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (GOT - Fixup + Addend) >> 12
|
|
R_RISCV_GOT_HI20,
|
|
|
|
/// High 20 bits of PC relative relocation
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend + 0x800) >> 12
|
|
R_RISCV_PCREL_HI20,
|
|
|
|
/// Low 12 bits of PC relative relocation, used by I type instruction format
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend) & 0xFFF
|
|
R_RISCV_PCREL_LO12_I,
|
|
|
|
/// Low 12 bits of PC relative relocation, used by S type instruction format
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend) & 0xFFF
|
|
R_RISCV_PCREL_LO12_S,
|
|
|
|
/// High 20 bits of 32-bit pointer value relocation
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target + Addend + 0x800) >> 12
|
|
R_RISCV_HI20,
|
|
|
|
/// Low 12 bits of 32-bit pointer value relocation
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target + Addend) & 0xFFF
|
|
R_RISCV_LO12_I,
|
|
|
|
/// Low 12 bits of 32-bit pointer value relocation, used by S type instruction
|
|
/// format
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target + Addend) & 0xFFF
|
|
R_RISCV_LO12_S,
|
|
|
|
/// 8 bits label addition
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target + *{1}Fixup + Addend)
|
|
R_RISCV_ADD8,
|
|
|
|
/// 16 bits label addition
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target + *{2}Fixup + Addend)
|
|
R_RISCV_ADD16,
|
|
|
|
/// 32 bits label addition
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target + *{4}Fixup + Addend)
|
|
R_RISCV_ADD32,
|
|
|
|
/// 64 bits label addition
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target + *{8}Fixup + Addend)
|
|
R_RISCV_ADD64,
|
|
|
|
/// 8 bits label subtraction
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target - *{1}Fixup - Addend)
|
|
R_RISCV_SUB8,
|
|
|
|
/// 16 bits label subtraction
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target - *{2}Fixup - Addend)
|
|
R_RISCV_SUB16,
|
|
|
|
/// 32 bits label subtraction
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target - *{4}Fixup - Addend)
|
|
R_RISCV_SUB32,
|
|
|
|
/// 64 bits label subtraction
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target - *{8}Fixup - Addend)
|
|
R_RISCV_SUB64,
|
|
|
|
/// 8-bit PC-relative branch offset
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend)
|
|
R_RISCV_RVC_BRANCH,
|
|
|
|
/// 11-bit PC-relative jump offset
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend)
|
|
R_RISCV_RVC_JUMP,
|
|
|
|
/// 6 bits label subtraction
|
|
///
|
|
/// Fixup expression
|
|
/// Fixup <- (Target - *{1}Fixup - Addend)
|
|
R_RISCV_SUB6,
|
|
|
|
/// Local label assignment
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target + Addend)
|
|
R_RISCV_SET6,
|
|
|
|
/// Local label assignment
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target + Addend)
|
|
R_RISCV_SET8,
|
|
|
|
/// Local label assignment
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target + Addend)
|
|
R_RISCV_SET16,
|
|
|
|
/// Local label assignment
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target + Addend)
|
|
R_RISCV_SET32,
|
|
|
|
/// 32 bits PC relative relocation
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- (Target - Fixup + Addend)
|
|
R_RISCV_32_PCREL,
|
|
|
|
/// An auipc/jalr pair eligible for linker relaxation.
|
|
///
|
|
/// Linker relaxation will replace this with R_RISCV_RVC_JUMP or R_RISCV_JAL
|
|
/// if it succeeds, or with R_RISCV_CALL_PLT if it fails.
|
|
CallRelaxable,
|
|
|
|
/// Alignment requirement used by linker relaxation.
|
|
///
|
|
/// Linker relaxation will use this to ensure all code sequences are properly
|
|
/// aligned and then remove these edges from the graph.
|
|
AlignRelaxable,
|
|
|
|
/// 32-bit negative delta.
|
|
///
|
|
/// Fixup expression:
|
|
/// Fixup <- Fixup - Target + Addend
|
|
NegDelta32,
|
|
};
|
|
|
|
/// Returns a string name for the given riscv edge. For debugging purposes
|
|
/// only
|
|
const char *getEdgeKindName(Edge::Kind K);
|
|
} // namespace riscv
|
|
} // namespace jitlink
|
|
} // namespace llvm
|
|
|
|
#endif
|