class OrcAArch64

Declaration

class OrcAArch64 { /* full declaration omitted */ };

Declared at: llvm/include/llvm/ExecutionEngine/Orc/OrcABISupport.h:88

Member Variables

public static const unsigned int PointerSize = 8
public static const unsigned int TrampolineSize = 12
public static const unsigned int StubSize = 8
public static const unsigned int StubToPointerMaxDisplacement = 1U << 27
public static const unsigned int ResolverCodeSize = 288

Method Overview

  • public static void writeIndirectStubsBlock(char * StubsBlockWorkingMem, llvm::JITTargetAddress StubsBlockTargetAddress, llvm::JITTargetAddress PointersBlockTargetAddress, unsigned int MinStubs)
  • public static void writeResolverCode(char * ResolverWorkingMem, llvm::JITTargetAddress ResolverTargetAddress, llvm::JITTargetAddress ReentryFnAddr, llvm::JITTargetAddress RentryCtxAddr)
  • public static void writeTrampolines(char * TrampolineBlockWorkingMem, llvm::JITTargetAddress TrampolineBlockTargetAddress, llvm::JITTargetAddress ResolverAddr, unsigned int NumTrampolines)

Methods

static void writeIndirectStubsBlock(
    char* StubsBlockWorkingMem,
    llvm::JITTargetAddress
        StubsBlockTargetAddress,
    llvm::JITTargetAddress
        PointersBlockTargetAddress,
    unsigned int MinStubs)

Description

Write NumStubs indirect stubs to working memory at StubsBlockWorkingMem. Stubs will be written as if linked at StubsBlockTargetAddress, with the Nth stub using the Nth pointer in memory starting at PointersBlockTargetAddress.

Declared at: llvm/include/llvm/ExecutionEngine/Orc/OrcABISupport.h:120

Parameters

char* StubsBlockWorkingMem
llvm::JITTargetAddress StubsBlockTargetAddress
llvm::JITTargetAddress PointersBlockTargetAddress
unsigned int MinStubs

static void writeResolverCode(
    char* ResolverWorkingMem,
    llvm::JITTargetAddress ResolverTargetAddress,
    llvm::JITTargetAddress ReentryFnAddr,
    llvm::JITTargetAddress RentryCtxAddr)

Description

Write the resolver code into the given memory. The user is responsible for allocating the memory and setting permissions. ReentryFnAddr should be the address of a function whose signature matches void* (*)(void *TrampolineAddr, void *ReentryCtxAddr). The ReentryCtxAddr argument of writeResolverCode will be passed as the second argument to the function at ReentryFnAddr.

Declared at: llvm/include/llvm/ExecutionEngine/Orc/OrcABISupport.h:103

Parameters

char* ResolverWorkingMem
llvm::JITTargetAddress ResolverTargetAddress
llvm::JITTargetAddress ReentryFnAddr
llvm::JITTargetAddress RentryCtxAddr

static void writeTrampolines(
    char* TrampolineBlockWorkingMem,
    llvm::JITTargetAddress
        TrampolineBlockTargetAddress,
    llvm::JITTargetAddress ResolverAddr,
    unsigned int NumTrampolines)

Description

Write the requested number of trampolines into the given memory, which must be big enough to hold 1 pointer, plus NumTrampolines trampolines.

Declared at: llvm/include/llvm/ExecutionEngine/Orc/OrcABISupport.h:111

Parameters

char* TrampolineBlockWorkingMem
llvm::JITTargetAddress TrampolineBlockTargetAddress
llvm::JITTargetAddress ResolverAddr
unsigned int NumTrampolines